

# PCI Master/Target MegaCore Function with DMA

### April 1997, ver. 1

#### Data Sheet

# Features

- pci\_a MegaCore<sup>™</sup> function implementing a 32-bit peripheral component interconnect (PCI) interface
- Optimized for FLEX<sup>®</sup> 10K architecture
- Hardware tested

- Dramatically shortens design cycles
- Simulation circuit board included
- Extensive simulation testing
- Includes test vectors
- OpenCore<sup>™</sup> feature allows designers to instantiate and simulate designs in MAX+PLUS<sup>®</sup> II prior to purchase
- Uses approximately 950 FLEX logic elements (LEs), which is about 50% the capacity of an EPF10K30 device
- Fully-compliant design (see "Compliance Summary" on page 3), including
  - 32-bit, 33-MHz operation
  - Simplified local side (DMA control engine) interface
  - Fully simulated with required protocol test scenarios
  - Hardware tested
- PCI master features:
  - Memory read/write
  - Bus parking
  - Fully integrated DMA engine including address counter register, byte counter register, control & status register, interrupt status register
  - Configurable interrupt source, including DMA terminal count, master abort, target abort, local side interrupt
  - 64-byte (16 double words or DWORDS) RAM buffer implemented in FLEX 10K embedded array blocks (EABs)
  - Zero wait state PCI read (107 Mbytes per second); zero wait state PCI write (102 Mbytes per second)
- PCI target features:
  - Type zero configuration space
  - Parity error detection
  - Memory read/write and configuration read/write
  - Target abort, retry, and disconnect
  - 1 Mbyte of target space
- Configuration registers: device ID, vendor ID, status, command, class code, revision ID, header type, latency timer, one memory base address, subsystem ID, subsystem vendor ID, maximum latency, minimum grant, interrupt pin, and interrupt line

| Introduction | This data sheet provides operating information for the pci_a Me<br>function and includes the following topics: | gaCore |
|--------------|----------------------------------------------------------------------------------------------------------------|--------|
|              | Ordering Information                                                                                           |        |
|              | General Description                                                                                            |        |
|              | Compliance Summary                                                                                             |        |
|              | PCI Bus Signals                                                                                                |        |
|              | Local Side Signals                                                                                             |        |
|              | Function Prototype                                                                                             |        |
|              | Parameters                                                                                                     |        |
|              | Functional Description                                                                                         | 10     |
|              | Sustained Tri-State Signal Operation                                                                           | 11     |
|              | Master Device Signals & Signal Assertion                                                                       | 12     |
|              | Target Device Signals & Signal Assertion                                                                       |        |
|              | Parity Signal Operation                                                                                        |        |
|              | Bus Master Commands                                                                                            | 15     |
|              | Configuration Registers                                                                                        | 15     |
|              | Vendor ID Register (Offset = 00 Hex)                                                                           | 17     |
|              | Device ID Register (Offset = 02 Hex)                                                                           |        |
|              | Command Register (Offset = 04 Hex)                                                                             | 18     |
|              | Status Register: (Offset = 06 Hex)                                                                             | 19     |
|              | Revision ID Register (Offset = 08 Hex)                                                                         | 20     |
|              | Class Code Register (Offset = 09 Hex)                                                                          |        |
|              | Latency Timer Register (Offset = 0D Hex)                                                                       | 20     |
|              | Header Type Register (Offset = 0E Hex)                                                                         | 21     |
|              | Base Address Register Zero (Offset = 10 Hex)                                                                   | 21     |
|              | Subsystem Vendor ID Register (Offset = 2C Hex)                                                                 | 22     |
|              | Subsystem ID Register (Offset = 2E Hex)                                                                        | 22     |
|              | Interrupt Line Register (Offset = 3C Hex)                                                                      | 22     |
|              | Interrupt Pin Register (Offset = 3D Hex)                                                                       | 23     |
|              | Minimum Grant Register (Offset = 3E Hex)                                                                       | 23     |
|              | Maximum Latency Register (Offset = 3F Hex)                                                                     | 23     |
|              | PCI Bus Transactions                                                                                           | 24     |
|              | Target Transactions                                                                                            |        |
|              | Configuration Transactions                                                                                     | 30     |
|              | Master Transactions                                                                                            | 32     |
|              | DMA Operation                                                                                                  |        |
|              | Target Address Space                                                                                           | 39     |
|              | Internal Target Registers Memory Map                                                                           | 39     |
|              | DMA Registers                                                                                                  | 40     |
|              | DMA Transactions                                                                                               |        |
|              | General Programming Guidelines                                                                                 | 47     |
|              | Applications                                                                                                   |        |
|              | PCI SIG Protocol Checklists                                                                                    |        |
|              | PCI SIG Test Bench Summary                                                                                     | 59     |
|              | References                                                                                                     | 65     |

# Ordering Information

General Description The Altera<sup>®</sup> pci\_a ordering code is PLSM-PCI/A. The maintenance agreement ordering code is PLAESW-MCORE.

The pci\_a MegaCore function provides a timely solution for integrating 32-bit PCI peripheral devices, and is fully tested to meet the requirements of the PCI specification. The pci\_a is optimized for the EPF10K30RC240-3 device, reducing the design task and enabling designers to focus efforts on the custom logic surrounding the PCI interface. The pci\_a function is intended for use in Altera FLEX 10K devices with remaining logic resources available for user-defined local side (DMA control engine) customization. See Figure 1.





# **Compliance Summary**

The pci\_a function is compliant with the requirements specified in the PCI Special Interest Group's (SIG) *PCI Local Bus Specification, Rev. 2.1,* and *Compliance Checklist, Rev. 2.1*. The pci\_a function was verified using the applicable scenarios listed in Table 1. For a detailed listing of tests performed, see "PCI SIG Test Bench Summary" on page 59.

| Test<br>Scenario # | Test Scenario Description                                                | Simulation<br>File Name<br>Note (1) |
|--------------------|--------------------------------------------------------------------------|-------------------------------------|
| 1.1                | PCI bus device speed                                                     | pcicc101                            |
| 1.2                | PCI bus single data phase target abort cycles                            | pcicc102                            |
| 1.3                | PCI bus single data phase target retry cycles                            | pcicc103                            |
| 1.4                | PCI bus single data phase target disconnect cycles                       | pcicc104                            |
| 1.5                | PCI bus multi-data phase target abort cycles                             | pcicc105                            |
| 1.6                | PCI bus multi-data phase target retry cycles                             | pcicc106                            |
| 1.7                | PCI bus multi-data phase target disconnect cycles                        | pcicc107                            |
| 1.8                | PCI bus multi-data phase & trdyn cycles                                  | pcicc108                            |
| 1.9                | PCI bus data parity error single cycles                                  | pcicc109                            |
| 1.10               | PCI bus data parity error multi-data phase cycles                        | pcicc110                            |
| 1.11               | PCI bus master time-out                                                  | pcicc111                            |
| 1.13               | PCI bus master parking                                                   | pcicc113                            |
| 1.14               | PCI bus master arbitration                                               | pcicc114                            |
| 2.5                | Target ignores reserved commands (including dual address)                | pcicc205                            |
| 2.6                | Target reception of configuration cycles                                 | pcicc206                            |
| 2.8                | Target receives configuration cycles with address and data parity errors | pcicc208                            |
| 2.9                | Target receives memory cycles                                            | pcicc209                            |
| 2.10               | Target receives memory cycles with address and data parity errors        | pcicc210                            |

### Note:

(1) The file extension depends on the type of simulation file used, e.g., simulation channel file (**.scf**), vector file (**.vec**), or VHDL file.

# **PCI Bus Signals**

The following PCI bus signals are used by the pci\_a function:

- *Input*—Standard input-only signal.
- *Output*—Standard output-only signal.
- *Bidirectional*—Tri-state input/output signal.

- Sustained tri-state—Signal that is driven by one agent at a time (e.g., device or host operating on the PCI bus). An agent that drives a sustained tri-state pin low must actively drive it high for one clock cycle before tri-stating it. Another agent cannot drive a sustained tri-state signal any sooner than one clock cycle after it is released by the previous agent.
- Open-drain—Signal that is wire-ORed with other agents. The signaling agent asserts the open-drain signal, and a weak pull-up resistor deasserts the open-drain signal. The pull-up resistor may take two or three PCI bus clock cycles to restore the open-drain signal to its inactive state.

Table 2 summarizes the PCI bus signals interfacing the pci\_a to the PCI bus. See "Local Side Signals" on page 7 for information on local side signals.

|          |                                              | -        |                                                                                                                                                                                                                                             |
|----------|----------------------------------------------|----------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Name     | Туре                                         | Polarity | Description                                                                                                                                                                                                                                 |
| clk      | Input                                        | _        | Clock. The clk input provides the reference signal for all other PCI interface signals, except rstn and intan.                                                                                                                              |
| rstn     | Input                                        | Low      | Reset. The rstn input initializes the FLEX 10K PCI interface circuitry, and can be asserted asynchronously to the PCI bus clk edge. When active, the PCI output signals are tri-stated and the open-drain signals, such as serrn, float.    |
| gntn     | Input                                        | Low      | Grant. The gntn input indicates to the master device that it has control of the PCI bus. Every master device has a pair of arbitration lines (gntn and reqn) that connect directly to the arbiter.                                          |
| reqn     | Output                                       | Low      | Request. The reqn output indicates to the arbiter that the master wants to gain control of the PCI bus to perform a transaction.                                                                                                            |
| ad[310]  | Tri-State                                    | -        | Address/data bus. The ad[310] bus is a time-<br>multiplexed address/data bus; each bus transaction consists<br>of an address phase followed by one or more data phases.<br>The data phases occur when irdyn and trdyn are both<br>asserted. |
| cben[30] | Tri-State<br>Master: Output<br>Target: Input | Low      | Command/byte enable. The cben[30] bus is a time-<br>multiplexed command/byte enable bus. During the address<br>phase this bus indicates the command; during the data<br>phase this bus indicates byte enables.                              |
| par      | Tri-State                                    | _        | Parity. The par signal is a tri-stated output of even parity.<br>The number of 1s on ad[310], cben[30], and par is<br>an even number.                                                                                                       |

Table 2. PCI Signals Interfacing the pci\_a to the PCI Bus (Part 1 of 2)

| Name                      | Туре                                                      | Polarity | Description                                                                                                                                                                                                                                                                                                                                                                       |  |
|---------------------------|-----------------------------------------------------------|----------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| framen<br><i>Note (1)</i> | Sustained<br>Tri-State<br>Master: Output<br>Target: Input | Low      | Frame. The framen is an output from the current bus master<br>that indicates the beginning and duration of a bus operation.<br>When framen is initially asserted, the address and<br>command signals are present on the ad[310] and<br>cben[30] buses. The framen signal remains asserted<br>during the data operation and is deasserted to identify the<br>end of a transaction. |  |
| irdyn                     | Sustained<br>Tri-State<br>Master: Output<br>Target: Input | Low      | Initiator ready. The irdyn signal is an output from a bus<br>master to its target and indicates that the bus master can<br>complete a data transaction. In a write transaction, irdyn<br>indicates that valid data is on the ad[310] bus. In a read<br>transaction, irdyn indicates that the master is ready to<br>accept the data on the ad[310] bus.                            |  |
| devseln                   | Sustained<br>Tri-State<br>Master: Input<br>Target: Output | Low      | Device select. Target asserts devseln to indicates that the target has decoded its own address.                                                                                                                                                                                                                                                                                   |  |
| trdyn<br><i>Note (1)</i>  | Sustained<br>Tri-State<br>Master: Input<br>Target: Output | Low      | Target ready. The trdyn is a target output, indicating that<br>the target can complete the current data transaction. In a<br>read operation, trdyn indicates that the target is providing<br>data on the ad[310] bus. In a write operation, trdyn<br>indicates that the target is ready to accept data on the<br>ad[310] bus.                                                     |  |
| stopn<br><i>Note (1)</i>  | Sustained<br>Tri-State<br>Master: Input<br>Target: Output | Low      | Stop. The stopn signal is a target device request that indicates to the bus master to stop the current transaction.                                                                                                                                                                                                                                                               |  |
| idsel                     | Input                                                     | High     | Initialization device select. The idsel input is a chip select for configuration read or write operations.                                                                                                                                                                                                                                                                        |  |
| perrn                     | Sustained<br>Tri-State                                    | Low      | Parity error. The perrn signal indicates a data parity error.                                                                                                                                                                                                                                                                                                                     |  |
| serrn                     | Open-Drain                                                | Low      | System error. The serrn signal indicates system error and address parity error.                                                                                                                                                                                                                                                                                                   |  |
| intan                     | Open-Drain                                                | Low      | Interrupt A. The intan signal is an active-low interrupt to the host, and must be used for any single-function device requiring an interrupt capability.                                                                                                                                                                                                                          |  |

#### Note:

Г

To allow the pci\_a to pass the PCI set-up time requirement, the framen, trdyn, and stopn signals are split into (1) two unidirectional (input, output) signals. For example, the PCI signal trdyn is connected to the input trdyn\_in and the output trdyn\_out. The input trdyn\_in is connected to a dedicated input on the FLEX 10K device, and the output trdyn\_out is connected to an I/O pin on the FLEX 10K device.

The PCI bus and FLEX 10K devices allow Joint Test Action Group (JTAG) boundary-scan testing (BST). To use JTAG BST, designers should connect the PCI bus JTAG pins with the FLEX 10K device JTAG pins. See Table 3.

| Table 3. Optional JTAG Signals |        |          |                                                                                                                   |  |  |
|--------------------------------|--------|----------|-------------------------------------------------------------------------------------------------------------------|--|--|
| Name                           | Туре   | Polarity | Description                                                                                                       |  |  |
| ТСК                            | Input  | High     | Test clock. The TCK input is used to clock test mode and test data in and out of the device.                      |  |  |
| TMS                            | Input  | High     | Test mode select. The TMS input is used to control the state of the test access port (TAP) control in the device. |  |  |
| TDI                            | Input  | High     | Test data. The TDI input is used to shift the test data and instruction into the device.                          |  |  |
| TDO                            | Output | High     | Test data. The TDO output is used to shift the test data and instruction out of the device.                       |  |  |

# **Local Side Signals**

Table 4 summarizes the pci\_a signals that interface the pci\_a to the local side peripheral device(s).

| Table 4. pci_a Signals Interfacing the pci_a to the Local Side (Part 1 of 3) |       |          |                                                                                                                                                                                                                                                                        |  |  |
|------------------------------------------------------------------------------|-------|----------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|
| Name                                                                         | Туре  | Polarity | Description                                                                                                                                                                                                                                                            |  |  |
| l_irqn                                                                       | Input | Low      | Local side interrupt request. The local side peripheral<br>device asserts 1_irqn to signal a PCI bus interrupt.<br>For example, when the local side peripheral device<br>requires a DMA transfer, it could use the 1_irqn<br>input to request servicing from the host. |  |  |
| l_holdn                                                                      | Input | Low      | Local hold. When asserted, 1_holdn suspends the current DMA transfer. As long as 1_holdn is active, data transfers cannot occur between the pci_a and the local side peripheral device.                                                                                |  |  |
| l_req                                                                        | Input | High     | Local DMA request. The local side peripheral device<br>asserts 1_req, which signals the pci_a to request<br>permission for a PCI DMA operation.                                                                                                                        |  |  |
| l_dat_in[310]                                                                | Input | _        | Local data bus input. The l_dat_in[310] input is<br>driven active by the local side peripheral device during<br>pci_a-initiated DMA write transactions (i.e., local<br>side DMA read transactions) and PCI bus target read<br>transactions.                            |  |  |

| Name       | Туре   | Polarity | Description                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                         |
|------------|--------|----------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| l_adr[180] | Output | _        | Local target address. The 1_adr[180] output<br>represents the 128K DWORDS of target register<br>space available to the local side peripheral device.                                                                                                                                                                                                                                                                                                                                                                                                                                |
| l_csn      | Output | Low      | Local target chip select. When active, 1_csn notifies<br>the peripheral device of an impending target<br>transaction. Any PCI master device can read or write<br>to a local side peripheral device through the pci_a.<br>The 1_ackn and the 1_csn outputs are never<br>asserted at the same time.                                                                                                                                                                                                                                                                                   |
| 1_rdn      | Output | Low      | Read. The pci_a asserts l_rdn to signal a read<br>access to the local side peripheral device. The pci_a<br>uses the l_rdn for reading from peripheral device<br>target registers and for PCI DMA write transactions. A<br>PCI DMA write transaction begins when the pci_a<br>reads data from the peripheral device. For target read<br>operations, the pci_a asserts the l_csn and l_rdn<br>signals. For DMA read operations, the pci_a asserts<br>the l_ackn and l_rdn signals.                                                                                                    |
| l_wrn      | Output | Low      | Write. The pci_a asserts l_wrn to signal a write<br>access to the local side peripheral device. The pci_a<br>uses the l_wrn output for writing to peripheral device<br>target registers and for PCI DMA read transactions. A<br>PCI DMA read operation begins when the pci_a<br>reads data from memory over the PCI bus and into the<br>internal EAB RAM buffer, and then writes the data out<br>to the peripheral device. For a write operation, the<br>pci_a also asserts either l_csn for target accesses<br>to the local side, or l_ackn for DMA accesses to the<br>local side. |
| l_ackn     | Output | Low      | Local DMA acknowledge. When low, 1_ackn notifies<br>the local side peripheral device that it has been<br>granted a DMA read or write transaction. The<br>peripheral device can then transfer data to or from the<br>PCI bus through the pci_a.                                                                                                                                                                                                                                                                                                                                      |

Table 4. pci\_a Signals Interfacing the pci\_a to the Local Side (Part 2 of 3)

| Name           | Туре   | Polarity | Description                                                                                                                                                                                                                                        |
|----------------|--------|----------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| l_clk          | Output | -        | Local PCI clock. The l_clk is a buffered version of<br>the PCI bus clock and is used by the local side<br>peripheral device to synchronize all control logic to the<br>pci_a.                                                                      |
| l_reset        | Output | High     | Local reset. The pci_a asserts the l_reset output<br>to reset the local side peripheral device. The<br>l_reset output is active during a PCI master reset<br>and follows the state of the l_rst bit (bit 2 of the DMA<br>control status register). |
| 1_dat_out[310] | Output | -        | Local data bus output. The pci_a drives the<br>l_dat_out[310] output during pci_a-initiated<br>DMA read transactions (i.e., local side DMA write<br>transactions) and PCI target write transactions.                                               |

# **Function Prototype**

The Altera Hardware Description Language (AHDL<sup>™</sup>) Function Prototype of the pci\_a is shown below:

```
FUNCTION pci_a (clk, framen_in, gntn, idsel,
 l_dat_in[31..0], l_holdn, l_irqn, l_req, rstn,
 stopn_in, trdyn_in)
WITH (SUBSYSTEM_ID, SUBSYSTEM_VEND_ID, DEVICE_ID,
 DEVICE_VEND_ID, CLASS_CODE, REVISION_ID)
RETURNS (framen_out, l_ackn, l_adr[18..0], l_clk,
 l_csn, l_dat_out[31..0], l_ rdn, l_reset, l_wrn,
 stopn_out, trdyn_out, ad[31..0], cben[3..0], devseln,
 intan, irdyn, par, perrn, reqn, serrn);
```

# **Parameters**

The pci\_a parameters set read-only PCI bus configuration registers in the pci\_a; these registers are called device identification registers. See "Configuration Registers" on page 15 for more information on device ID registers. Table 5 describes the parameters of the pci\_a function.

| Table 5. Parameters |                        |                                |                              |  |  |
|---------------------|------------------------|--------------------------------|------------------------------|--|--|
| Name                | Value<br>(Hexadecimal) | Default Value<br>(Hexadecimal) | Description                  |  |  |
| CLASS_CODE          | 24-bit                 | FF0000                         | Class code register          |  |  |
| DEVICE_ID           | 16-bit                 | 0001                           | Device ID register           |  |  |
| DEVICE_VEND_ID      | 16-bit                 | 1172                           | Device vendor ID register    |  |  |
| REVISION_ID         | 8-bit                  | 01                             | Revision ID register         |  |  |
| SUBSYSTEM_ID        | 16-bit                 | 0000                           | Subsystem ID register        |  |  |
| SUBSYSTEM_VEND_ID   | 16-bit                 | 0000                           | Subsystem vendor ID register |  |  |

# Functional Description

The pci\_a function consists of three main components:

- A defined 64-byte PCI bus configuration register space and master control logic
- PCI bus target interface control logic, including target decode and register read/write signals
- Embedded DMA control engine, which operates with four registers and includes a 64-byte (16 DWORD) RAM buffer, and local side interface DMA control logic, including read/write control and PCI bus arbitration for master/target accesses

Figure 2 shows the pci\_a block diagram.



Figure 2. pci\_a Block Diagram

# **Sustained Tri-State Signal Operation**

The PCI specification defines signals that are constantly sampled by different bus agents yet driven by one agent at a time, as sustained tristate signals. For example, framen is constantly sampled by different PCI bus targets (to detect the start of a transaction), and yet driven by one PCI bus master at a time.

For sustained tri-state signals, the PCI specification requires using one clock cycle to drive the signals inactive before being tri-stated. The PCI specification also requires that any sustained tri-state signal being released, such as the master device releasing ad[31..0] after asserting the address on a read operation, be given a full clock cycle to tri-state before another device can drive it.

The PCI specification defines a turn-around cycle as the clock cycle where a sustained tri-state signal is being tri-stated so that another bus agent can drive it. Turn-around cycles prevent contention on the bus.

# **Master Device Signals & Signal Assertion**

Figure 3 illustrates the PCI-compliant master device signals interfacing the pci\_a with the PCI bus. The signals are grouped by functionality, and signal directions are illustrated from the perspective of the pci\_a operating as a master on the PCI bus.

A pci\_a master sequence begins with the assertion of reqn to request mastership of the PCI bus. After receiving gntn from the arbiter (usually the PCI host bridge) and after the bus idle state is detected, the pci\_a initiates the address phase by asserting framen and driving both the PCI address on ad[31..0] and the bus command on cben[3..0]for one clock cycle.

When the pci\_a is ready to present data on the bus, it asserts irdyn. At this point, the pci\_a master logic monitors the control signals driven by the target device. (A target device is determined by the decoding of the address and command signals presented on the PCI bus during the address phase of the transaction.) The target device drives the control signals devseln, trdyn, and stopn to indicate one of the following:

- The data transaction has been decoded and accepted.
- The target device is ready for the data operation. (When both trdyn and irdyn are active, a data word is clocked from the sending to the receiving device.)
- The master device should stop the current transaction.



Figure 3. pci\_a Master Device Signals

# **Target Device Signals & Signal Assertion**

Figure 4 illustrates the PCI-compliant target device signals interfacing the pci\_a with the PCI bus. The signals are grouped by functionality, and signal directions are illustrated from the perspective of the pci\_a operating as a target on the PCI bus.

A pci\_a target sequence begins when the master device asserts framen and drives the address of the target and the command on the PCI bus. When the target device decodes its address on the PCI bus, it asserts devseln to indicate to the master that it has accepted the transaction. The master will then assert irdyn to indicate to the target device that:

- For a read operation, the master device can complete a data transaction.
- For a write operation, valid data is on the ad[31..0] bus.

When the pci\_a functions as the selected target device, it will drive the control signals devseln, trdyn, and stopn as discussed in "Master Device Signals & Signal Assertion" on page 12.

As a target device, the pci\_a only supports single-cycle accesses; therefore, the pci\_a simultaneously drives stopn and trdyn active. When qualified by an active irdyn signal, a data word is clocked from the sending to the receiving device.



### Figure 4. pci\_a Target Device Signals

### **Parity Signal Operation**

All bus cycles include parity. Every device that transmits on the ad[31..0] bus must also drive the par signal, including master devices outputting the address. Because parity on the PCI bus is even, the number of logic 1s on ad[31..0], cben[3..0], and par must be even. Parity checking is not required, but can be enabled through the agent's PCI command register. Address parity errors are presented on the serrn output, and data parity errors are presented on the perrn output. The par bit lags the ad[31..0] bus by one clock cycle, and parity error signals lag the par bit by one clock cycle; thus, parity error signals lag the address or data by two clock cycles.

# **Bus Master Commands**

When the pci\_a acquires mastership of the PCI bus, it can initiate a memory read or memory write command. During the address phase of a transaction, the cben[3..0] bus is used to indicate the transaction type. See Table 6.

The pci\_a supports memory read/write and configuration read/write commands. When operating as a master device, the pci\_a executes standard memory read and write operations. When operating as a target, the pci\_a responds to standard memory read and write transactions. The pci\_a also responds to configuration read and write operations.

Table 6 summarizes the PCI bus commands that are supported by the pci\_a.

| Table 6. PCI Bus Command Support Summary |                     |                |                |  |  |
|------------------------------------------|---------------------|----------------|----------------|--|--|
| cben[30] Value                           | Bus Command Cycle   | Target Support | Master Support |  |  |
| 0110                                     | Memory read         | Yes            | Yes            |  |  |
| 0111                                     | Memory write        | Yes            | Yes            |  |  |
| 1010                                     | Configuration read  | Yes            | No             |  |  |
| 1011                                     | Configuration write | Yes            | No             |  |  |

# Configuration Registers

Each logical PCI bus device includes a block of 64 configuration DWORDS reserved for the implementation of its configuration registers. The format of the first 16 DWORDS is defined by the PCI SIG's **PCI Local Bus** *Specification* compliance checklist, revision 2.1, which defines two header formats, type one and type zero. Header type one is used for PCI-to-PCI bridges; header type zero is used for all other devices, including the pci\_a.

Table 7 displays the defined 64-byte configuration space. The registers within this range are used to identify the device, control PCI bus functions, and provide PCI bus status. The shaded areas indicate registers that are supported by the pci\_a.

| Address | Byte                                |               |               |                 |  |  |
|---------|-------------------------------------|---------------|---------------|-----------------|--|--|
|         | 3                                   | 2             | 1             | 0               |  |  |
| 00H     | Devi                                | ce ID         | Venc          | lor ID          |  |  |
| 04H     | Status I                            | Register      | Command       | d Register      |  |  |
| 08H     |                                     | Class Code    |               | Revision ID     |  |  |
| 0CH     | BIST                                | Header Type   | Latency Timer | Cache Line Size |  |  |
| 10H     |                                     | Base Addres   | ss Register 0 |                 |  |  |
| 14H     |                                     | Base Addres   | ss Register 1 |                 |  |  |
| 18H     | Base Address Register 2             |               |               |                 |  |  |
| 1CH     | Base Address Register 3             |               |               |                 |  |  |
| 20H     |                                     | Base Addres   | ss Register 4 |                 |  |  |
| 24H     |                                     | Base Addres   | ss Register 5 |                 |  |  |
| 28H     |                                     | Card Bus      | CIS Pointer   |                 |  |  |
| 2CH     | Subsystem ID Subsystem Vendor ID    |               |               |                 |  |  |
| 30H     | Expansion ROM Base Address Register |               |               |                 |  |  |
| 34H     | Reserved                            |               |               |                 |  |  |
| 38H     | Reserved                            |               |               |                 |  |  |
| 3CH     | Maximum<br>Latency                  | Minimum Grant | Interrupt Pin | Interrupt Line  |  |  |

Table 8 summarizes the pci\_a-supported configuration registers address map. Read/write refers to the status at run time, i.e., from the perspective of other PCI bus agents. Designers can set some of the read-only registers at design time by setting the parameters when the pci\_a is instantiated in MAX+PLUS II. For example, the device ID register value can be modified from its default value by changing the DEVICE\_ID parameter in MAX+PLUS II. The specified default state is defined as the state of the register when the PCI bus is reset.

| Table 8. pci_a-Supported Configuration Registers Address Map |                                    |                         |            |            |                            |  |
|--------------------------------------------------------------|------------------------------------|-------------------------|------------|------------|----------------------------|--|
| Address Offset<br>(Hexadecimal)                              | Range<br>Reserved<br>(Hexadecimal) | Bytes Used/<br>Reserved | Read/Write | Mnemonic   | Register Name              |  |
| 00                                                           | 00-01                              | 2/2                     | Read       | ven_id     | Vendor ID                  |  |
| 02                                                           | 02-03                              | 2/2                     | Read       | dev_id     | Device ID                  |  |
| 04                                                           | 04-05                              | 2/2                     | Read/Write | comd       | Command                    |  |
| 06                                                           | 06-07                              | 2/2                     | Read/Write | status     | Status                     |  |
| 08                                                           | 08-08                              | 1/1                     | Read       | rev_id     | Revision ID                |  |
| 09                                                           | 09-0B                              | 3/3                     | Read       | class      | Class code                 |  |
| 0D                                                           | 0D-0D                              | 1/1                     | Read/Write | lat_tmr    | Latency timer              |  |
| 0E                                                           | 0E-0E                              | 1/1                     | Read       | header     | Header type                |  |
| 10                                                           | 10-13                              | 4/4                     | Read/Write | bar0       | Base address register zero |  |
| 2C                                                           | 2C-2D                              | 2/2                     | Read       | sub_ven_id | Subsystem vendor ID        |  |
| 2E                                                           | 2E-2F                              | 2/2                     | Read       | sub_id     | Subsystem ID               |  |
| 3C                                                           | 3C-3C                              | 1/1                     | Read/Write | int_ln     | Interrupt line             |  |
| 3D                                                           | 3D-3D                              | 1/1                     | Read       | int_pin    | Interrupt pin              |  |
| 3E                                                           | 3E-3E                              | 1/1                     | Read       | min_gnt    | Minimum grant              |  |
| 3F                                                           | 3F-3F                              | 1/1                     | Read       | max_lat    | Maximum latency            |  |

# Vendor ID Register (Offset = 00 Hex)

Vendor ID is a 16-bit read-only register that identifies the manufacturer of the device (e.g., Altera for the pci\_a). The value of this register is assigned by the PCI SIG; the default value of this register is the Altera vendor ID value, which is 1172 hex. However, by setting the DEVICE\_VEND parameter (see Table 5), designers can change the value of the vendor ID register to their PCI SIG-assigned vendor ID value. See Table 9.

| Table 9. Vendor ID Register Format      |        |      |               |  |
|-----------------------------------------|--------|------|---------------|--|
| Data Bit Mnemonic Read/Write Definition |        |      |               |  |
| 150                                     | ven_id | Read | PCI vendor ID |  |

# Device ID Register (Offset = 02 Hex)

Device ID is a 16-bit read-only register that identifies the type of device. The value of this register is assigned by the manufacturer (e.g., Altera assigned the value of the device ID register for the pci\_a). The default value of the device ID register is 0001 hex; however, designers can change the value of the device ID register by setting the parameter DEVICE\_ID (see Table 5).

# Command Register (Offset = 04 Hex)

Command is a 16-bit read and write register that provides basic control over the ability of the pci\_a to respond to and/or perform PCI bus accesses. See Table 10.

| Table 10. Command Register Format |          |            |                                                                                                                                                                                                                                                                                                            |  |
|-----------------------------------|----------|------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Data Bit                          | Mnemonic | Read/Write | Definition                                                                                                                                                                                                                                                                                                 |  |
| 0                                 | Unused   | -          | -                                                                                                                                                                                                                                                                                                          |  |
| 1                                 | mem_ena  | Read/Write | Memory access enable. When high, mem_ena enables<br>the pci_a to respond to the PCI bus memory<br>accesses as a target. Because the DMA registers are<br>set via memory target accesses, the mem_ena bit must<br>be set as part of the initialization operation for the<br>pci_a to perform DMA transfers. |  |
| 2                                 | mstr_ena | Read/Write | Master enable. When high, mstr_ena enables the pci_a to acquire mastership of the PCI bus. For the pci_a to perform DMA transfers, the mstr_ena bit must be set as a part of the initialization operation.                                                                                                 |  |
| 53                                | Unused   | -          | -                                                                                                                                                                                                                                                                                                          |  |
| 6                                 | perr_ena | Read/Write | Parity error enable. When high, perr_ena enables the pci_a to report parity errors via the perrn output.                                                                                                                                                                                                   |  |
| 7                                 | Unused   | -          | _                                                                                                                                                                                                                                                                                                          |  |
| 8                                 | serr_ena |            | System error enable. When high, serr_ena enables<br>the pci_a to report address parity errors via the<br>serrn output. However, to signal a system error, the<br>perr_ena bit must also be high.                                                                                                           |  |
| 159                               | Unused   | -          | -                                                                                                                                                                                                                                                                                                          |  |

# Status Register: (Offset = 06 Hex)

Status is a 16-bit register that provides the status of bus-related events. Read transactions to the status register behave normally. However, write transactions are different from typical write transactions in that bits in the status register can be cleared but not set. A bit in the status register is cleared by writing a logic one to that bit. For example, writing the value 4000 hex to the status register clears bit number 14 and leaves the rest of the bits unchanged. The default value of the status register is 0400 hex. See Table 11.

| Data Bit | Mnemonic    | Read/Write | Definition                                                                                                                                                                                                                                                                                                                              |
|----------|-------------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 70       | Unused      | -          | -                                                                                                                                                                                                                                                                                                                                       |
| 8        | dat_par_rep | Read/Write | Data parity reported. When high, dat_par_rep<br>indicates that during a read transaction the pci_a<br>asserted the perrn output as a master device, or that<br>during a write transaction the perrn was asserted by<br>a target device. This bit is high only when the<br>perr_ena bit (bit 6 of the command register) is also<br>high. |
| 109      | devsel_tim  | Read       | Device select timing. The devsel_tim bits indicate target access timing of the pci_a via the devseln output. The pci_a is designed to be a slow target device.                                                                                                                                                                          |
| 11       | Unused      | -          | -                                                                                                                                                                                                                                                                                                                                       |
| 12       | tar_abrt    | Read/Write | Target abort. When high, tar_abrt indicates that the current target device transaction has been terminated                                                                                                                                                                                                                              |
| 13       | mstr_abrt   | Read/Write | Master abort. When high, mstr_abrt indicates that the current master device transaction has been terminated.                                                                                                                                                                                                                            |
| 14       | serr_set    | Read/Write | Signaled system error. When high, serr_set<br>indicates that the pci_a drove the serrn output<br>active, i.e., an address phase parity error has<br>occurred.                                                                                                                                                                           |
| 15       | det_par_err | Read/Write | Detected parity error. When high, det_par_err<br>indicates that the pci_a detected either an address or<br>data parity error. Even if parity error reporting is<br>disabled (via perr_ena), the pci_a will set the<br>det_par_err bit.                                                                                                  |

### Table 11. Status Register Format

# **Revision ID Register (Offset = 08 Hex)**

Revision ID is an 8-bit read-only register that identifies the revision number of the device. The value of this register is assigned by the manufacturer (e.g., Altera for the pci\_a). Therefore, the default value of the revision ID register is set as the revision number of the pci\_a. See Table 12. However, designers can change the value of the revision ID register by setting the REVISION\_ID parameter (see Table 5).

| Table 12. Revision ID Register Format   |        |      |                 |  |
|-----------------------------------------|--------|------|-----------------|--|
| Data Bit Mnemonic Read/Write Definition |        |      |                 |  |
| 70                                      | rev_id | Read | PCI revision ID |  |

# Class Code Register (Offset = 09 Hex)

Class code is a 24-bit read-only register divided into three sub-registers: base class, sub-class, and programming interface. Refer to the *PCI Local Bus Specification*, rev. 2.1 for detailed bit information. See Table 13. The default value of the class code register is FF0000 hex; however, designers can change the value by setting the CLASS\_CODE parameter (see Table 5).

| Table 13. Class Code Register Format    |       |      |            |  |
|-----------------------------------------|-------|------|------------|--|
| Data Bit Mnemonic Read/Write Definition |       |      |            |  |
| 230                                     | class | Read | Class code |  |

# Latency Timer Register (Offset = 0D Hex)

The latency timer register is an 8-bit register with bits 2, 1, and 0 tied to GND. The register defines the maximum amount of time, in PCI bus clock cycles, that the pci\_a can retain ownership of the PCI bus. After initiating a transaction, the pci\_a decrements its latency timer by one on the rising edge of each clock. The default value of the latency timer register is 00 hex. See Table 14.

| Table 14. Latency Timer Register Format |         |            |                        |  |
|-----------------------------------------|---------|------------|------------------------|--|
| Data Bit Mnemonic Read/Write Definition |         |            |                        |  |
| 20                                      | lat_tmr | Read       | Latency timer register |  |
| 73                                      | lat_tmr | Read/Write | Latency timer register |  |

# Header Type Register (Offset = OE Hex)

Header type is an 8-bit read-only register that identifies the pci\_a as a single-function device. The default value of the header type register is 00 hex. See Table 15.

| Table 15. Header Type Register Format   |                                |  |  |  |  |
|-----------------------------------------|--------------------------------|--|--|--|--|
| Data Bit Mnemonic Read/Write Definition |                                |  |  |  |  |
| 70                                      | 70 header Read PCI header type |  |  |  |  |

# Base Address Register Zero (Offset = 10 Hex)

Base address register zero (BAR0) consists of a 12-bit register (bits 31 through 20) that determines the base memory address of the pci\_a target space. The default value of the base address register is 0000.0000 hex. See Table 16.

| Table 16. Base | Table 16. Base Address Register Format |            |                                                                                                                                                                                                                                              |  |  |  |
|----------------|----------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Data Bit       | Mnemonic                               | Read/Write | Definition                                                                                                                                                                                                                                   |  |  |  |
| 0              | mem_ind                                | Read       | Memory indicator. The mem_ind bit indicates whether<br>the register is I/O or a memory address decoder. In the<br>pci_a, the mem_ind bit is tied to GND, which indicates<br>a memory address decoder.                                        |  |  |  |
| 21             | mem_type                               | Read       | Memory type. The mem_type bits indicate the type of memory that can be implemented in the pci_a memory address space. These bits are tied to GND, which indicates that the memory block can be located anywhere in the 32-bit address space. |  |  |  |
| 3              | pre_fetch                              | Read       | Memory prefetchable. The pre_fetch bit indicates<br>whether the block of memory defined by BAR0 is<br>prefetchable by the host bridge. In the pci_a, the<br>address space is not prefetchable, i.e., it reads as low.                        |  |  |  |
| 194            | Unused                                 | -          | _                                                                                                                                                                                                                                            |  |  |  |
| 3120           | bar0                                   | Read/write | Base address register 0.                                                                                                                                                                                                                     |  |  |  |

# Subsystem Vendor ID Register (Offset = 2C Hex)

Subsystem vendor ID is a 16-bit read-only register that identifies add-in cards designed by different vendors but with the same functional device on the card. The value of this register is assigned by the PCI SIG. See Table 17. The default value of the subsystem vendor ID register is 0000 hex; however, designers can change the value by setting the SUBSYSTEM\_VEND\_ID parameter (see Table 5).

| Table 17. Subsystem Vendor ID Register Format |             |      |                         |  |
|-----------------------------------------------|-------------|------|-------------------------|--|
| Data Bit Mnemonic Read/Write Definition       |             |      |                         |  |
| 150                                           | sub_vend_id | Read | PCI subsystem/vendor ID |  |

# Subsystem ID Register (Offset = 2E Hex)

Subsystem ID register identifies the subsystem; the value of this register is defined by the subsystem vendor, i.e., the designer. See Table 18. The default value of the subsystem ID register is 0000 hex; however, designers can change the value by setting the SUBSYSTEM\_ID parameter (see Table 5).

| Table 18. Subsystem ID Register Format  |        |      |                  |  |  |
|-----------------------------------------|--------|------|------------------|--|--|
| Data Bit Mnemonic Read/Write Definition |        |      |                  |  |  |
| 150                                     | sub_id | Read | PCI subsystem ID |  |  |

# Interrupt Line Register (Offset = 3C Hex)

The interrupt line register consists of an 8-bit register that defines to which system interrupt request line (on the system interrupt controller) the intan output is routed. The interrupt line register is written to by the system software on power-up; the default value is FF hex. See Table 19.

| Table 19. Interrupt Line Register Format |        |            |                         |  |
|------------------------------------------|--------|------------|-------------------------|--|
| Data Bit Mnemonic Read/Write Definition  |        |            |                         |  |
| 70                                       | int_ln | Read/write | Interrupt line register |  |

# Interrupt Pin Register (Offset = 3D Hex)

The interrupt pin register consists of an 8-bit read-only register that defines the pci\_a PCI bus interrupt request line to be intan. The default value of the interrupt pin register is 01 hex. See Table 20.

| Table 20. Interrupt Pin Register Format |         |      |                        |  |
|-----------------------------------------|---------|------|------------------------|--|
| Data Bit Mnemonic Read/Write Definition |         |      |                        |  |
| 70                                      | int_pin | Read | Interrupt pin register |  |

# Minimum Grant Register (Offset = 3E Hex)

Minimum grant register consists of an 8-bit read-only register that defines the length of time the pci\_a would like to retain mastership of the PCI bus. The value set in this register indicates the required burst period length in 250-ns increments. The pci\_a requests a timeslice of 4 microseconds. The default state of the minimum grant register is 10 hex. See Table 21.

| Table 21. Minimum Grant Register Format |          |            |                        |  |
|-----------------------------------------|----------|------------|------------------------|--|
| Data Bit                                | Mnemonic | Read/Write | Definition             |  |
| 70                                      | min_gnt  | Read       | Minimum grant register |  |

# Maximum Latency Register (Offset = 3F Hex)

The maximum latency register is an 8-bit read-only register that defines the frequency in which the pci\_a would like to gain access to the PCI bus. The value of the maximum latency register is set to 00 hex, which indicates that the pci\_a has no major requirements for maximum latency. See Table 22.

| Table 22. Maximum Latency Register Format |          |            |                          |  |
|-------------------------------------------|----------|------------|--------------------------|--|
| Data Bit                                  | Mnemonic | Read/Write | Definition               |  |
| 70                                        | max_lat  | Read       | Maximum latency register |  |

# PCI Bus Transactions

This section describes pci\_a PCI bus transactions. The following should be considered when reading the diagrams in this section:

- All pci\_a accesses to the PCI bus are quad-byte, or 32-bit transfers; therefore, all byte enables are active for the duration of data transfers.
- Although Figures 5 through 14 show PCI bus signals as tri-stated when not driven by the pci\_a, they are actually high due to the pullup resistors used to keep sustained tri-state signals at a logic high while the signals are not being driven by a PCI bus agent.

The pci\_a accesses the PCI bus for three types of transactions:

- Target
- Device configuration
- Master

# **Target Transactions**

A target read or write transaction begins after the master acquires mastership of the PCI bus and asserts framen to indicate the beginning of a bus transaction. The pci\_a latches the address and command signals on the first clock edge when framen is asserted and starts the address decode phase.

# Target Read Transactions

The pci\_a supports two types of target read transactions:

- Internal target read—Target read transaction from the internal DMA registers
- *External target read*—Target read transaction from the local side target memory space

The sequence of events in both target read transactions is identical; however, the timing is not. A target read transaction from the local side target memory space requires more time because the pci\_a must wait for the local side to supply it with data.

### **Internal Target Read Transaction**

Immediately after the address phase (clock 4), the master deasserts framen and asserts irdyn, indicating both of the following:

- The transaction contains a single data phase.
- The master device is ready to read the data that the pci\_a has presented on the ad[31..0] bus.

The master device tri-states the ad[31..0]bus in clock five after the pci\_a latches the address. The pci\_a can drive the ad[31..0] bus beginning in clock six. If the master is attempting a burst access, it will keep both framen and irdyn signals asserted. However, because the pci\_a does not support target bursts, it will assert stopn to indicate a disconnect to the master. The master will subsequently end the transaction by deasserting framen and asserting irdyn for one clock cycle.

In Figure 5, the pci\_a asserts devseln in clock seven, which indicates to the master device that the pci\_a has accepted the transaction. The devseln is then sampled by the master device on the rising-edge of clock eight, which is slow decode timing. The pci\_a is a slow decode device during target and configuration read or write transactions. Figure 5 shows the timing of a pci\_a internal target read transaction.





In Figure 5, the pci\_a asserts trdyn and stopn in clock eight to indicate that valid data is on the ad[31..0] bus and a disconnect is desired. Data is transferred during clock eight when irdyn and trdyn are active and latched by the master device on the rising-edge of clock nine. In the case of an attempted burst transfer, the PCI specification requires that a target device that does not support burst transfers must issue a disconnect during the first data phase. Because of the PCI specification, the pci\_a always asserts stopn and trdyn at the same time.

The master drives the par active in clock five for address parity, and the pci\_a drives par active in clock nine for data parity. In a target read transaction, the master device drives the perrn signal to indicate data parity errors.

In clock nine, because the data has been sampled, the pci\_a releases the ad[31..0]bus and the master releases cben[3..0]. The devseln, trdyn, and stopn signals are driven high in clock nine and released by the pci\_a one clock later. Thus, the sustained tri-state signal requirement is met, i.e., driving the signal high for one clock cycle before releasing it.

### **External Target Read Transaction**

Again, the sequence of events in an external target read transaction is identical to an internal target read transaction. However, because the pci\_a must wait for the local side to supply it with data, a target read transaction from the local side target memory space requires more time. Also, because a DMA access to the local side takes precedence over any other access to the local side, an external target read transaction is allowed to complete only when the DMA is in an idle state. If an external target read transaction is received by the pci\_a while the DMA is not in an idle state, the pci\_a signals a retry.

Figures 6 shows the timing of a pci\_a external target read transaction.



#### Figure 6. External Target Read Transaction

### Target Write Transactions

The pci\_a supports two types of target write transactions:

- Internal target write: Target write to internal DMA registers
- External target write: Target write to the local side target memory space

The sequence of events in both target write transactions is identical; however, the timing may not be.

### **Internal Target Write Transaction**

Immediately after the address phase, the master deasserts framen and asserts irdyn, indicating the following:

- The transaction contains a single data phase.
- The master device is ready to write data on the ad[31..0]bus for the target device to receive.

If the master device is not ready for the data phase to begin, irdyn is delayed and framen is not deasserted until the clock where irdyn goes active. If the master is attempting a burst access, it will keep both framen and irdyn signals asserted. However, because the pci\_a does not support target bursts, it will assert stopn to indicate a disconnect to the master. The master will subsequently end the transaction by deasserting framen and asserting irdyn for one clock cycle.

In Figure 7, the pci\_a asserts devseln in clock seven, which indicates to the master device that the pci\_a has accepted the transaction. The devseln signal is then sampled by the master device on the rising edge of clock eight, which is slow decode timing.

In Figure 7, where the data phase occurs in clocks five through eight, the master device drives data on the ad[31..0] bus simultaneously with the assertion of irdyn in clock five. To indicate completion of the data phase and to request a bus disconnect, the pci\_a asserts trdyn and stopn in clock eight. Data is transferred during clock eight when irdyn and trdyn are active, and latched by the pci\_a on the rising edge of clock nine. In the case of an attempted burst write transfer, the PCI specification requires that a target device that does not support burst transfers must issue a disconnect during the first data phase. Because of the PCI specification, the pci\_a always asserts stopn and trdyn at the same time.

The master device drives par active in clock five for parity of the address bits, and clock six for parity of the data bits. In a target write transaction, the pci\_a drives perrn to indicate data parity errors.

In clock nine, because the data has been sampled, the pci\_a releases the ad[31..0] and cben[3..0] buses. One clock later par is released by the master device and devseln, trdyn, and stopn are release by the pci\_a. The devseln, trdyn, and stopn are driven high in clock nine and released one clock later. Figure 7 shows the timing of an internal target write transaction.



Figure 7. Internal Target Write Transaction

### **External Target Write Transaction**

Again, the sequence of events in an external target write transaction is identical to an internal target write transaction. However, the timing may be different.

To allow an external target write transaction to complete faster, the pci\_a provides a single address and a single data holding register. When an external target write access takes place, the pci\_a stores the address and data in its internal holding registers and completes the transfer on the PCI bus. The pci\_a will subsequently assert its l\_csn signal to indicate to the local side that there is a pending target access; once clock later (clock 10), the l\_wrn and l\_dat\_out signals are also asserted. Figure 8 shows the timing of an external target write transaction.



#### Figure 8. External Target Write Transaction

# **Configuration Transactions**

A configuration transaction is generated by either a host-to-PCI bridge or PCI-to-PCI bridge access. In the address phase of a configuration transaction, the PCI bridge will drive the idsel signal of the PCI bus agent that it wants to access. If a PCI bus agent decodes the configuration command and detects its idsel to be high, the agent will claim the configuration access and assert devsel.

### PCI Configuration Read Transaction

Figure 9 shows the timing of a pci\_a configuration read transaction. The protocol is identical to the protocol discussed in the "Target Read Transactions" on page 24 except for the idsel signal, which is active during the address phase of a configuration transaction.



Figure 9. Configuration Read Transaction

# PCI Configuration Write Transaction

Figure 10 shows the timing of a pci\_a configuration write transaction. The protocol is identical to the protocol discussed in the "Target Write Transactions" on page 27 except for the idsel signal, which is active during the address phase of a configuration transactions.



### Figure 10. Configuration Write Transaction

### **Master Transactions**

Master transactions in the pci\_a are controlled by the DMA engine. A pci\_a master transaction begins after the user loads the appropriate values in the DMA register (see "General Programming Guidelines" on page 47 for more detailed information on DMA register loading). The pci\_a waits for the local side to assert l\_req, which indicates to the pci\_a that it can begin the DMA operation.

In a DMA read (PCI to local side) transaction, the pci\_a immediately asserts reqn to acquire mastership of the PCI bus. After the arbiter asserts gntn, the pci\_a begins the address phase by asserting framen and driving the address on the ad[31..0] bus and the command on the cben[3..0] bus.

In a DMA write (local side to PCI) transaction, the pci\_a first reads up to 16 DWORDS from the local side and stores them in its internal RAM buffer. At this point, the DMA asserts requ to acquire mastership of the PCI bus. After the arbiter asserts gntn, the pci\_a begins the address phase.

### Master Read Transactions

The pci\_a supports two types of master read transactions:

- Single-cycle master read
- Master burst read

### Single-Cycle Master Read Transaction

In a master read transaction, data is being transferred from the PCI side to the local side. Assuming the pci\_a has acquired mastership of the PCI bus, the start of a master read transaction is indicated when the pci\_a asserts framen.

After the master read transaction is initiated, the target devices latch the address and command on the clock edge when framen is active and start the address decode. The pci\_a is not ready to read data until clock five; therefore, framen is not deasserted and irdyn is not asserted until clock five.

The selected target device asserts devseln in clock three, and devseln is sampled by the pci\_a on the rising-edge of clock four, which depicts a fast decode target device.

To indicate that it is ready to send data, the target device simultaneously asserts trdyn and drives data on the ad[31..0] bus beginning in clock four. The data phase begins in clock five when irdyn and trdyn are active and finishes on the rising edge of clock six with data latched by the pci\_a.

The pci\_a drives the par signal active in clock three for parity of the address and command bits, and the selected target drives par active in clock six for parity of the data and byte enable bits.

The pci\_a releases the ad[31..0] bus in clock three, the cben[3..0] bus in clock six, and the par signal in clock four.

Figure 11 shows the timing of a pci\_a master read transaction. The figure assumes the pci\_a has already acquired mastership of the PCI bus.



Figure 11. Single-Cycle Master Read Transaction

### **Master Burst Read Transaction**

The protocol for the address phase of a master burst read transaction is identical to "Single-Cycle Master Read Transaction" on page 33. After the address phase, the protocol changes to reflect the additional read transactions.

After the master burst read transaction is initiated, the selected target device asserts devseln in clock three, and the pci\_a samples devseln on the rising edge of clock five. This example displays a fast decode target. The target device then signals to the pci\_a that it is ready to send data by driving trdyn and the ad[31..0] bus active in clock four.

The pci\_a drives par active in clock three for parity of the address and command bits. In clock six the target device drives par active for parity of the first data phase (Data0). The target device also drives par active in clocks 7, 8, and 9 for parity of the second, third and fourth data phases.

Figure 12 shows a 16-byte data transaction, with the data phases occurring in four consecutive clock cycles. The data phase begins in clock five and ends in clock eight when the pci\_a releases framen, which indicates the start of the final data phase.

Because the data has been read, the target device simultaneously releases devseln, trdyn, and the ad[31..0]bus when the pci\_a releases irdyn in clock nine.



### Master Write Transactions

The pci\_a supports two types of master write transactions:

- Single-cycle master write
- Master burst write

### Single-Cycle Master Write Transaction

In a master write transaction, data is transferred from the local side to the PCI side. Assuming the pci\_a has acquired mastership of the PCI bus, the start of a master device write transaction is indicated when the pci\_a asserts framen.

After the master device write transaction is initiated, the target devices latch the address and command on the clock edge when framen is active and start the address decode. Data from pci\_a master device write transactions is not available until clock five; therefore, framen is not deasserted and irdy is not asserted until clock five.

The selected target device asserts devseln in clock four and is sampled by the pci\_a in clock five, which depicts a medium decode target device.

To indicate that it is ready to receive data, the target device drives trdyn active in clock five. Then, the pci\_a drives data on the ad[31.0] bus beginning in clock five and simultaneously with the assertion of irdyn. The data phase begins in clock five when irdyn and trdyn are active, and ends on the rising-edge of clock six with data latched by the selected target device.

The pci\_a drives par active in clock three for parity of the address and command bits and clock six for parity of the data and byte enable bits.

Because the data phase is complete, the pci\_a releases the ad[31..0]bus and cben[3..0] in clock six. One clock later, par is released by the pci\_a, and devseln and trdyn are released by the target device. To meet the requirement of driving a sustained tri-state signal high for one clock cycle before releasing it, the pci\_a drives irdyn high in clock six before releasing it in clock seven.

Figure 13 shows the timing of a pci\_a master write transaction. The figure assumes the pci\_a has already acquired mastership of the PCI bus.



Figure 13. Single-Cycle Master Write Transaction

#### **Master Burst Write Transaction**

The protocol for master burst write transactions from the address phase to data phase one is identical to "Single-Cycle Master Write Transaction" on page 35. From data phase two, the protocol changes to reflect the additional write transactions.

After the master burst write transaction is initiated, the selected target device asserts devseln in clock four, and the pci\_a samples devseln on the rising edge of clock five. This example depicts a medium decode target. The target device signals to the master device that it is ready to receive data by driving trdyn active in clock five.

The master burst write transaction example in Figure 14 shows the data phases occurring in clocks five, six, seven, and nine when irdyn and trdyn are both active.

To ensure data synchronization on the pci\_a internal data path pipeline, a wait state for master burst write transactions is inserted by the pci\_a in clock eight. If the target does not insert a wait state during the burst write transaction, the pci\_a will insert only one wait state for the entire burst transfer. However, if the target inserts additional wait states during the burst write transaction, the pci\_a will insert additional wait states. The final data transfer occurs when the pci\_a simultaneously asserts irdyn and deasserts framen in clock nine.

The pci\_a drives the par active in clock three for parity of the address bits and clock six for parity of the data bits.

Figure 14 shows the timing of a pci\_a burst write transaction, which depicts a 16-byte data transfer.



Figure 14. Master Burst Write Transaction

**DMA Operation** This section provides operating details of the DMA engine, and is divided into the following sub-sections:

- Target address space
- Internal target registers memory map
- DMA registers
- DMA Transactions
- General programming guidelines

# **Target Address Space**

The pci\_a memory-mapped target registers (internal and external) are read and/or written over the PCI bus in BAR0 memory space. Accesses to or from BAR0 memory space occur in 32-bit transfers. Table 23 lists the pci\_a memory space address map. The pci\_a BAR0 address space is 1 Mbyte of contiguous address divided into two 512-kbyte spaces. The lower 512-kbyte region (internal target address space) contains the pci\_a DMA control registers, and the upper region (external target address space) contains user-defined memory space.

| Table 23. Me    | Table 23. Memory Space Address Map |                |                         |             |                                            |  |  |  |
|-----------------|------------------------------------|----------------|-------------------------|-------------|--------------------------------------------|--|--|--|
| Memory<br>Space | Block Size<br>(DWORDS)             | Address Offset | Words Used/<br>Reserved | Read/ Write | Description                                |  |  |  |
| BAR0            | 128k                               | 00000h-7FFFFh  | 4/128k                  | Read/Write  | DMA registers                              |  |  |  |
| BAR0            | 128k                               | 80000h-FFFFFh  | 128k/128k               | Read/Write  | User-defined memory space<br>(128k DWORDS) |  |  |  |

# Internal Target Registers Memory Map

Internal pci\_a target address space is used for the DMA registers, including the DMA control/status register, DMA address counter register, DMA byte counter register and the interrupt status register. Table 24 lists the pci\_a DMA registers memory map.

| Table 24. Internal Target Registers Memory Map                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |     |            |         |          |                      |  |
|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----|------------|---------|----------|----------------------|--|
| Range         Bytes         Read/Write         Mnemonic         Default State           Reserved         Used/Reserved         Keserved         Keserved |     |            |         |          | Register Name        |  |
| 00000h-00003h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1/4 | Read/write | dma_csr | 00000000 | DMA control/status   |  |
| 00004h-00007h                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 4/4 | Read/write | dma_acr | 00000000 | DMA address counter  |  |
| 00008h-0000Bh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 2/4 | Read/write | dma_bcr | 00000000 | DMA byte counter     |  |
| 0000Ch-0000Fh                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | 1/4 | Read       | dma_isr | 00000000 | DMA interrupt status |  |

# **DMA Registers**

This section describes the DMA registers. The specified default state is defined as the state of the storage element when the PCI bus is reset. The pci\_a contains the following DMA registers:

- Control and status
- Address counter
- Byte counter
- Interrupt status

## Control & Status Register (Offset = 00000 Hex)

The DMA control and status register (dma\_csr) configures the pci\_a DMA engine, directs the pci\_a DMA operation, and provides status of the current memory transfer. See Table 25.

| Table 25. D | Table 25. DMA Control & Status Register Format (Part 1 of 2) |            |                                                                                                                                                                                                                                                                                                                                              |  |  |  |
|-------------|--------------------------------------------------------------|------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Data Bit    | Mnemonic                                                     | Read/Write | Definition                                                                                                                                                                                                                                                                                                                                   |  |  |  |
| 0           | int_ena                                                      | Read/write | PCI interrupt enable. The int_ena bit enables the intan output when either the err_pend or dma_tc bits are driven high from the dma_isr, or when the l_irqn signal is active.                                                                                                                                                                |  |  |  |
| 1           | flush                                                        | Write      | Flush buffer. When high, flush marks all bytes in the internal EAB RAM queue as invalid and resets dma_tc and ad_loaded (bits 3 and 4 of the interrupt status register). The flush bit also resets itself; therefore, it always reads as zero. The flush bit should never be set while dma_on is set, because a DMA transfer is in progress. |  |  |  |
| 2           | l_rst                                                        | Read/write | Local reset. This bit serves as a software reset to the local side add-<br>on logic (see "Local Side Signals" on page 7). The l_reset output<br>of the pci_a is active as long as the l_rst bit is high. (The<br>l_reset output is also active for PCI bus resets.)                                                                          |  |  |  |

| Table 25. DMA Control & Status Register Format (Part 2 of 2) |          |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |  |
|--------------------------------------------------------------|----------|------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|
| Data Bit                                                     | Mnemonic | Read/Write | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |  |
| 3                                                            | write    | Read/write | Memory read/write. The write bit determines the direction of the pci_a DMA transfer. When write is high, the data flows to local memory from the PCI bus (PCI bus write); when write is low, the data flows from the local memory to the PCI bus (PCI bus read).                                                                                                                                                                                                                                                                                    |  |
| 4                                                            | dma_ena  | Read/write | DMA enable. When high, dma_ena allows the pci_a to respond to DMA requests from the local side (int_req) as long as the PCI bus activity is not stopped due to a pending interrupt, etc.                                                                                                                                                                                                                                                                                                                                                            |  |
| 5                                                            | tci_dis  | Read/write | Transfer complete interrupt disable. When high, tci_dis disables dma_tc (bit 3 of the DMA interrupt status register) from generating PCI bus interrupts.                                                                                                                                                                                                                                                                                                                                                                                            |  |
| 6                                                            | dma_on   | Read       | DMA on. When high, dma_on indicates that the pci_a can request<br>mastership of the PCI bus (reqn) if prompted by the local side (i.e.,<br>an active l_req). The dma_on bit is high when the address is loaded<br>(ad_loaded), the DMA is enabled, and there are no pending errors.<br>The DMA transfer sequence actually begins when the dma_on bit<br>becomes set. Under normal conditions (i.e., DMA is enabled and no<br>errors are pending) the dma_on bit becomes set when a write<br>transaction to the DMA address counter register occurs. |  |
| 317                                                          | Unused   | -          | _                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |  |

# Address Counter Register (Offset = 00004 Hex)

The DMA address counter register (dma\_acr) is a 32-bit register consisting of a 30-bit counter (bits 31..2) and 2 bits (bits 1..0) tied to GND. The dma\_acr contains the PCI bus address for the current memory transfer and is incremented after every data transfer on the PCI bus. PCI bus memory transfers initiated by the pci\_a must begin on DWORD boundaries. Reading the dma\_acr during a memory transfer is permitted and can be used for monitoring progress, but is not recommended for maximum efficiency. See Table 26.

| Table 26. DMA | Table 26. DMA Address Counter Register Format |  |  |  |  |  |
|---------------|-----------------------------------------------|--|--|--|--|--|
| Data Bit      | Data Bit Name Read/Write Definition           |  |  |  |  |  |
| 10            | 10 dma_acr Read Bits are tied to GND.         |  |  |  |  |  |
| 312           | 312 dma_acr Read/write 30-bit counter.        |  |  |  |  |  |

# Byte Counter Register (Offset = 00008 Hex)

The DMA byte counter register (dma\_bcr) is a 16-bit register consisting of a 14-bit counter (bits 15..2) and 2 bits (bits 1..0) tied to GND. The dma\_bcr holds the byte count for the current pci\_a -initiated memory transfer and decrements (by 4 bytes) after every data transfer on the PCI bus. PCI bus memory transfers initiated by the pci\_a must be DWORD transfers. Reading the dma\_bcr during a memory transfer is permitted and can be used for monitoring progress, but is not recommended for maximum efficiency. See Table 27.

| Table 27. DMA Byte Counter Register Format |           |            |                       |  |  |
|--------------------------------------------|-----------|------------|-----------------------|--|--|
| Data Bit Name Read/Write Definition        |           |            |                       |  |  |
| 10                                         | byte_cntr | Read       | Bits are tied to GND. |  |  |
| 152                                        | byte_cntr | Read/write | 14-bit counter.       |  |  |
| 3116                                       | Unused    | -          | -                     |  |  |

# Interrupt Status Register (Offset = 0000C Hex)

The DMA interrupt status register (dma\_isr) provides all interrupt source status signals to the interrupt handler. See Table 28.

| Table 28. DMA | Table 28. DMA Interrupt Status Register Format (Part 1 of 2) |            |                                                                                                                                                                                                                                                                                                                                                                                                                                |  |  |  |  |
|---------------|--------------------------------------------------------------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--|--|--|--|
| Data Bit      | Mnemonic                                                     | Read/Write | Definition                                                                                                                                                                                                                                                                                                                                                                                                                     |  |  |  |  |
| 0             | int_pend                                                     | Read       | The pci_a automatically asserts int_pend to<br>indicate that a pci_a interrupt is pending. The three<br>possible interrupt signals from the pci_a are<br>err_pend, dma_tc, and int_irq.                                                                                                                                                                                                                                        |  |  |  |  |
| 1             | err_pend                                                     | Read       | When high, err_pend indicates that an error occurred<br>during a pci_a-initiated PCI bus memory transfer, and<br>that the interrupt handler must read the PCI<br>configuration status register and clear the appropriate<br>bits. Any one of the following three PCI status register<br>bits can assert err_pend: mstr_abrt, tar_abrt,<br>and det_par_err. See "Control & Status Register<br>(Offset = 00000 Hex)" on page 40. |  |  |  |  |
| 2             | int_irq                                                      | Read       | When high, int_irq indicates that the local side is requesting an interrupt, i.e., the l_irqn input is asserted.                                                                                                                                                                                                                                                                                                               |  |  |  |  |

| Data Bit | Mnemonic  | Read/Write | Definition                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               |
|----------|-----------|------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 3        | dma_tc    | Read       | When high, dma_tc indicates that the pci_a-initiated<br>DMA transfer is complete. When the pci_a sets the<br>dma_tc bit, an interrupt will be generated on the<br>intan output as long as interrupts are enabled by the<br>int_ena bit (bit 0 of the dma_csr) and not disabled by<br>the tci_dis bit (bit 5 of the dma_csr). The dma_tc<br>bit is reset in one of three ways: a read transaction to<br>the dma_csr; a write transaction to the dma_csr), or by<br>asserting the rstn input from the PCI bus.                                                             |
| 4        | ad_loaded | Read       | When high, ad_loaded indicates that the address hat<br>been loaded via the dma_acr. This bit is cleared in on<br>of three ways: when the DMA operation is complete<br>and the dma_tc bit is set; when the flush bit is set; o<br>when the rstn input is asserted from the PCI bus. The<br>ad_loaded bit triggers the beginning of a DMA<br>operation and is automatically set by the pci_a when<br>a write operation to the dma_csr is performed.<br>Therefore, the dma_acr should be written to last when<br>a DMA operation is being loaded into the DMA<br>registers. |
|          |           |            |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          |

# **DMA Transactions**

The pci\_a DMA engine, which consists of a 64-byte RAM buffer and four programmable registers, is the control channel when the pci\_a acquires mastership of the PCI bus.

As a master device, the pci\_a performs DMA read and write transactions to system memory (via the host bridge), or to another PCI bus agent capable of accepting burst target data transfers.

A DMA read transaction from memory to the local side consists of two separate transfers:

- A PCI bus burst read from the PCI bus to the RAM buffer
- An equivalent number of DWORD transfers to the local side

All DMA read transactions from the pci\_a use the memory read command.

Similarly, a DMA write transaction from the pci\_a to system memory consists of two separate transfers:

- One to sixteen DWORD transfers from the local side to the DMA buffer
- A PCI burst write from the RAM buffer to a PCI agent.

All DMA (PCI bus) write transactions from the pci\_a use the memory write command.

#### PCI Bus DMA Read Transaction & Signal Sequence

In a PCI bus internal DMA read transaction, data is transferred from the system memory to the local side buffer. Specifically, a PCI bus DMA read consists of:

- A pci\_a master device read from a PCI agent to the pci\_a RAM buffer.
- A write from the pci\_a RAM buffer to the local side peripheral device.

The following is the signal sequence of a PCI bus DMA read transaction:

- The host sets up a DMA read transfer by writing appropriate values to the DMA registers. The DMA transfer sequence actually begins when the dma\_on bit becomes set. Under normal conditions (i.e., DMA is enabled and no errors are pending) the dma\_on bit becomes set when a write transaction to the DMA address counter register occurs.
- 2. The local side peripheral device asserts 1\_req to request a DMA transfer.
- 3. The pci\_a asserts reqn and waits for gntn to become active before assuming mastership of the PCI bus.
- 4. The pci\_a reads up to the 16 DWORDS from PCI bus system memory and loads the data into the pci\_a RAM buffer.
- 5. Once the PCI transfer is complete, the pci\_a asserts l\_ackn and l\_wrn to the local side peripheral device and transfers up to 16 DWORDS. Because the pci\_a does not have the local side address location where data is to be written, the local side is responsible for generating the address during a local side DMA transfer. In Figure 15 the address is not generated from the pci\_a.

- 6. The pci\_a writes the data from the pci\_a RAM buffer onto the l\_dat\_out[31..0] bus. When the last data word is written, the pci\_a disables l\_ackn and l\_wrn.
- If the dma\_bcr expiration occurs, the pci\_a drives intan. Otherwise, steps 2 through 5 are repeated until dma\_bcr expiration or until a DMA error occurs. See Figure 15.



#### Altera Corporation

### PCI Bus DMA Write Transaction & Signal Sequence

In a PCI bus internal DMA write transaction, data is transferred from the local side to system memory. Specifically, a PCI DMA write consists of:

- A transfer from the local side to the pci\_a RAM buffer.
- Apci\_a master write from the pci\_a RAM buffer to a PCI bus agent.

The following is the signal sequence of a PCI DMA write transaction:

- The host sets up a DMA write transfer by writing appropriate values to the DMA registers. The DMA transfer sequence actually begins when the dma\_on bit becomes set. Under normal conditions (i.e., DMA is enabled and no errors are pending) the dma\_on bit becomes set when a write transaction to the DMA address counter register occurs.
- The local side peripheral device asserts 1\_req to request a DMA transfer.
- The pci\_a function asserts l\_ackn and l\_rdn in response to the DMA request and latches up to 16 DWORDS from the local side peripheral device.
- 4. The pci\_a function reads the data from the l\_dat\_in[31..0] bus into the pci\_a RAM buffer. When the last DWORD in the DMA transfer is read, or when the RAM buffer is full, the pci\_a disables l\_ackn and l\_rdn.
- 5. The pci\_a function asserts reqn and waits for gntn to become active before assuming mastership of the PCI bus.
- 6. The pci\_a function transfers up to 16 DWORDS from its RAM buffer to the PCI bus target device.
- If the dma\_bcr expiration occurs (i.e., the specified number of data bytes have been transferred), the pci\_a drives intan. Otherwise, steps 2 through 5 are repeated until the dma\_bcr expiration or until a DMA error occurs. See Figure 16.



#### Figure 16. PCI Bus DMA Write Transaction (Local Side DMA Read Transaction)

# **General Programming Guidelines**

This section provides general programming guidelines and is divided into four tasks:

- Initializing the pci\_a
- DMA operation
- Interrupt service operation
- Clearing error bits

### Initializing the pci\_a

- 1. Configure the pci\_a-supported PCI bus configuration registers.
- 2. Configure the DMA dma\_csr. See Table 29.

#### PCI Master/Target MegaCore Function With DMA Data Sheet

| Step | Address<br>(Hexadecimal) | Register Name                   | Data<br>(Hexadecimal) | Definition                                                                                                                                                                                                               |
|------|--------------------------|---------------------------------|-----------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| 1    | 04                       | PCI bus command/status register | 0000.0146             | The value in the PCI bus command<br>register enables memory transfers,<br>master operations, the assertion of<br>perrn in case of data parity errors,<br>and the assertion of serrn in case<br>of address parity errors. |
| 2    | BAR0: 0.0000             | dma_csr                         | 0000.0011             | The value in the dma_csr<br>enables both the interrupts and the<br>DMA engine.                                                                                                                                           |

# DMA Operation

- 3. Load the dma\_bcr. (This step is optional if the byte count for the next block of data is the same as the current block.)
- 4. Load the dma\_acr, (see "Internal Target Registers Memory Map" on page 40). Loading the dma\_acr will set the dma\_on bit, which enables the pci\_a for the transfer to start as soon as the local side asserts l\_req.
- 5. Configure the local side peripheral device. This step will set up the address generation process necessary on the local side and allow the local side to assert 1\_req. However, if an intelligent PCI agent is operating on the local side (i.e., a microprocessor), this step may not be necessary.
- 6. The pci\_a function generates PCI interrupt (intan) to interrupt controller due to byte counter expiration. See Table 30.

| Tabl | Table 30. DMA Operation  |                          |                       |                                                                                                                             |  |  |  |
|------|--------------------------|--------------------------|-----------------------|-----------------------------------------------------------------------------------------------------------------------------|--|--|--|
| Step | Address<br>(Hexadecimal) | Register Name            | Data<br>(Hexadecimal) | Definition                                                                                                                  |  |  |  |
| 1    | BAR0: 0.0008             | dma_bcr                  | User-defined          | The amount of data (in bytes) for a DMA transfer.                                                                           |  |  |  |
| 2    | BAR0: 0.0004             | dma_acr                  | User-defined          | The PCI bus address where the transfer should begin. This address is automatically updated after every data transfer.       |  |  |  |
| 3    | BAR0: 8.0000             | External target register | User-defined          | This may involve several steps,<br>e.g., setting-up the local address<br>generator; asserting l_req from<br>the local side. |  |  |  |

# Interrupt Service Operation

- 7. Read the dma\_isr.
  - a. If the dma\_tc bit is high and err\_pend bit is low, indicating that the DMA operation was successful and that the pci\_a is ready for a new DMA transfer, go to step 3.
  - b. If the err\_pend bit is high, indicating that the DMA operation was stopped due to an error, go to step 9. You should clear the error bit prior to continuing. See Table 31.

| Tabl | Table 31. Interrupt Service Routine |               |                       |                                                                                                                              |  |  |
|------|-------------------------------------|---------------|-----------------------|------------------------------------------------------------------------------------------------------------------------------|--|--|
| Step | Address<br>(Hexadecimal)            | Register Name | Data<br>(Hexadecimal) | Instructions                                                                                                                 |  |  |
| 1    | BAR0: 0.000C                        | dma_isr       | User-defined          | The value in this register indicates<br>the progress of the DMA operation<br>and the reason the operation was<br>terminated. |  |  |

# Clearing Error Bits

- 8. Read the dma\_isr, and if the err\_pend bit is active, go to step 9.
- 9. Configure the dma\_csr by asserting the flush bit to clear the ad\_loaded bit (bit 4 of the dma\_isr).

- 10. Read the PCI bus configuration status register and determine which error is asserted (i.e., bit 15, 12, or 13).
- 11. Configure the pci\_a-supported PCI configuration status register and write a logic one to the appropriate error bit field. Writing a logic one to a bit in the status register will clear the bit; this feature allows the you to read the status register and write the same value to clear the error conditions.
- For specific programming information, go to *Application Note 86* (*Implementing the pci\_a Master/Target in FLEX 10K Devices*).

# **Applications** The pci\_a function is ideal for add-in applications. Figure 17 shows a typical connection to an intelligent local-side host. In this example, a target and a DMA control block are needed for access to the local side. The local side data bus is a bidirectional bus controlled by the l\_holdn output. The host asserts l\_holdn whenever it is accessing the local bus. Because the PCI bus address is often different than the local side address, the host is responsible for generating the local side address during a DMA access.

Figure 17. Local Side Interface to an Intelligent Local-Side Host with a Shared Memory Bus



Figure 18 shows a typical pci\_a connection to a dumb memory FIFO buffer. In this example, a target and a DMA control block are needed for access to the local side.

Because the local side does not have the intelligence to generate control and address signals during a DMA access, designers can set up the DMA control block to accept configuration and control data from the PCI bus via target access. Figure 18 illustrates the process via the bidirectional signals going between the two control blocks.

Figure 18. Local SIde Interface to a Dumb FIFO buffer



# PCI SIG Protocol Checklists

Tables 32 through 38 list the applicable PCI SIG protocol requirements from the *PCI Compliance Checklist, Rev.* 2.1. A check mark in the yes column indicates that the pci\_a meets the requirement. Checklists not applicable to the Altera FLEX 10K pci\_a function are not listed.

| CO# | Requirement                                                                                                                                                                      | Yes          | No |
|-----|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|
| 1   | Does each PCI resource have a configuration space based on the 256 byte template defined in section 6.1, with a predefined 64-byte header and a 192-byte device specific region? | ~            |    |
| 2   | Do all functions in the device support the vendor ID, device ID, command, status, header type and class code fields in the header?                                               | ~            |    |
| 3   | Is the configuration space available for access at all times?                                                                                                                    | $\checkmark$ |    |
| 4   | Are writes to reserved registers or read only bits completed normally and the data discarded?                                                                                    | ~            |    |
| 5   | Are reads to reserved or unimplemented registers, or bits, completed normally and a data value of 0 returned?                                                                    | ~            |    |
| 6   | Is the vendor ID a number allocated by the PCI SIG?                                                                                                                              | $\checkmark$ |    |
| 7   | Does the header type field have a valid encoding?                                                                                                                                | ~            |    |
| 8   | Do multi-byte transactions access the appropriate registers and are the registers<br>in "little endian" order?                                                                   | ~            |    |
| 9   | Are all read-only register values within legal ranges? For example, the interrupt pin register must only contain values 0-4.                                                     | ~            |    |
| 10  | Is the class code in compliance with the definition in appendix D?                                                                                                               | $\checkmark$ |    |
| 11  | Is the predefined header portion of configuration space accessible as bytes, words, and DWORDS?                                                                                  | ~            |    |
| 12  | Is the device a multi-function device?                                                                                                                                           |              | ~  |

| Location | Name                             | Required/Optional                                                                   | N/A          | Support              |
|----------|----------------------------------|-------------------------------------------------------------------------------------|--------------|----------------------|
| 00h-01h  | Vendor ID                        | Required.                                                                           |              | $\checkmark$         |
| 02h-03h  | Device ID                        | Required.                                                                           |              | ~                    |
| 04h-05h  | Command                          | Required.                                                                           |              | ~                    |
| 06h-07h  | Status                           | Required.                                                                           |              | ~                    |
| 08h      | Revision ID                      | Required.                                                                           |              | ~                    |
| 09h-0Bh  | Class code                       | Required.                                                                           |              | ~                    |
| 0Ch      | Cache line<br>size               | Required by master devices/functions that can generate Memory Write and Invalidate. | ~            |                      |
| 0Dh      | Latency timer                    | Required by master devices/functions that can burst more than two data phases.      |              | ~                    |
| 0Eh      | Header type                      | If the device is multi-functional, then bit 7 must be set to a 1.                   |              | ~                    |
| 0F       | BIST                             | Optional.                                                                           | $\checkmark$ |                      |
| 10h-13h  | BAR0                             | Optional.                                                                           |              | ~                    |
| 14h-27h  | BAR1-BAR5                        | Optional.                                                                           | $\checkmark$ |                      |
| 28h-2Bh  | Cardbus CIS pointer              | Optional.                                                                           | ~            |                      |
| 2Ch-2Dh  | Subsystem vendor ID              | Optional.                                                                           |              | ~                    |
| 2Eh-2Fh  | Subsystem ID                     | Optional.                                                                           |              | $\checkmark$         |
| 30h-33h  | Expansion<br>ROM base<br>address | Required for devices/functions that have expansion ROM.                             | ~            |                      |
| 34h-3Bh  | Reserved                         |                                                                                     |              |                      |
| 3Ch      | Interrupt line                   | Required by devices/functions that use an interrupt pin.                            |              | $\checkmark$         |
| 3Dh      | Interrupt pin                    | Required by devices/functions that use an interrupt pin.                            |              | <ul> <li></li> </ul> |
| 3Eh      | Min_Gnt                          | Optional.                                                                           |              | <ul> <li></li> </ul> |
| 3Fh      | Max_Lat                          | Optional.                                                                           | <u> </u>     |                      |

| Bit  | Name                           | Required/Optional                                                                                    | N/A          | Target | Master |
|------|--------------------------------|------------------------------------------------------------------------------------------------------|--------------|--------|--------|
| 0    | I/O space                      | Required if device/function has registers mapped into I/O space.                                     | $\checkmark$ |        |        |
| 1    | Memory space                   | Required if device/function responds to memory space accesses.                                       |              | ~      |        |
| 2    | Bus master                     | Required.                                                                                            |              |        | ~      |
| 3    | Special cycles                 | Required for devices/functions that can respond to special cycles.                                   | $\checkmark$ |        |        |
| 4    | Memory write<br>and invalidate | Required for devices/functions that generate Memory Write and Invalidate cycles.                     | ~            |        |        |
| 5    | VGA palette<br>snoop           | Required for VGA or graphical devices/functions that snoop VGA palette.                              | ~            |        |        |
| 6    | Parity error response          | Required.                                                                                            |              |        | ~      |
| 7    | Wait cycle<br>control          | Optional.                                                                                            | $\checkmark$ |        |        |
| 8    | serrn enable                   | Required if device/function has serrn pin.                                                           |              |        | ~      |
| 9    | Fast back-to-<br>back enable   | Required if master device/function can support fast back-<br>to-back cycles among different targets. | ~            |        |        |
| 1015 | Reserved                       |                                                                                                      |              |        |        |

| DS# | Requirement                                                        | Yes                   | No |
|-----|--------------------------------------------------------------------|-----------------------|----|
| 1   | Do all implemented read/write bits in the status reset to 0?       | ✓                     |    |
| 2   | Are read/write bits set to a 1 exclusively by the device/function? | <ul> <li>✓</li> </ul> |    |
| 3   | Are read/write bits reset to a 0 when PCI rstn is asserted?        | $\checkmark$          |    |
| 4   | Are read/write bits reset to a 0 by writing a 1 to the bit?        | ✓                     |    |

| Bit | Name                          | Required/Optional                                                          | N/A | Target               | Master |
|-----|-------------------------------|----------------------------------------------------------------------------|-----|----------------------|--------|
| 40  | Reserved                      | Required.                                                                  |     |                      |        |
| 5   | 66-MHz capable                | Required for 66-MHz capable devices.                                       | ~   |                      |        |
| 6   | UDF supported                 | Optional.                                                                  | ~   |                      |        |
| 7   | Fast back-to-<br>back capable | Optional.                                                                  | ~   |                      |        |
| 8   | Data parity detected          | Required.                                                                  |     |                      | ~      |
| 109 | DEVSEL timing                 | Required.                                                                  |     | <ul> <li></li> </ul> |        |
| 11  | Signaled target abort         | Required for devices/functions that are capable of signaling target abort. | ~   |                      |        |
| 12  | Received target abort         | Required.                                                                  |     |                      | ~      |
| 13  | Received<br>master abort      | Required.                                                                  |     |                      | ~      |
| 14  | Signaled<br>system error      | Required for devices/functions that are capable of asserting serrn.        |     |                      | ~      |
| 15  | Detected parity<br>error      | Required unless exempted per section 3.7.2.                                |     |                      | ~      |

| MP# | Requirement                                                                                                                           | Yes          | No |
|-----|---------------------------------------------------------------------------------------------------------------------------------------|--------------|----|
| 1   | All sustained tri-state signals are driven high for one clock before being tri-stated. (section 2.1)                                  | ~            |    |
| 2   | Interface under test (IUT) always asserts all byte enables during each data phase of a memory write Invalidate cycle. (section 3.1.1) | ~            |    |
| 3   | IUT always uses linear burst ordering for memory write invalidate cycles. (section 3.1.1)                                             | _            |    |
| 4   | IUT always drives irdyn when data is valid during a write transaction. (section 3.2.1)                                                | ~            |    |
| 5   | IUT only transfers data when both $irdyn$ and $trdyn$ are asserted on the same rising clock edge. (section 3.2.1)                     | ~            |    |
| 6   | Once the IUT asserts irdyn it never changes framen until the current data phase completes. (section 3.2.1)                            | ~            |    |
| 7   | Once the IUT asserts irdyn it never changes irdyn until the current data phase completes. (section 3.2.1)                             | ~            |    |
| 8   | IUT never uses reserved burst ordering (ad[10] = "01"). (section 3.2.2)                                                               | $\checkmark$ |    |

| MP# | Requirement                                                                                                                                 | Yes          | No |
|-----|---------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|
| 9   | IUT never uses reserved burst ordering (ad[10] = "11"). (section 3.2.2)                                                                     | $\checkmark$ |    |
| 10  | IUT always ignores configuration command unless <code>idsel</code> is asserted and <code>ad[10]</code> are "00". (section 3.2.2)            | ✓            |    |
| 11  | The IUT's address lines are driven to stable values during every address and data phase. (section 3.2.4)                                    | ✓            |    |
| 12  | The IUT's cben[30] output buffers remain enabled from the first clock of the data phase through the end of the transaction. (section 3.3.1) |              |    |
| 13  | The IUT's cben[30] lines contain valid byte enable information during the entire data phase. (section 3.3.1)                                |              |    |
| 14  | IUT never deasserts framen unless irdyn is asserted or will be asserted (section 3.3.3.1)                                                   |              |    |
| 15  | IUT never deasserts irdyn until at least one clock after framen is deasserted. (section 3.3.3.1)                                            |              |    |
| 16  | Once the IUT deasserts framen it never reasserts framen during the same transaction. (section 3.3.3.1)                                      | ~            |    |
| 17  | IUT never terminates with master abort once target has asserted devseln.                                                                    | ~            |    |
| 18  | IUT never signals master abort earlier than 5 clocks after framen was first sampled asserted. (section 3.3.3.1)                             | ~            |    |
| 19  | IUT always repeats an access exactly as the original when terminated by retry. (section 3.3.3.2.2)                                          | ~            |    |
| 20  | IUT never starts cycle unless gntn is asserted. (section 3.4.1)                                                                             | <            |    |
| 21  | IUT always tri-states cben[30] and ad[310] within one clock after gntn negation when bus is idle and framen is negated. (section 3.4.3)     | ~            |    |
| 22  | IUT always drives cben[30] and ad[310] within eight clocks of gntn assertion when bus is idle. (section 3.4.3)                              | <            |    |
| 23  | IUT always asserts $irdyn$ within eight clocks on all data phases. (section 3.5.2)                                                          | <            |    |
| 24  | IUT always begins lock operation with a read transaction. (section 3.6)                                                                     | _            |    |
| 25  | IUT always releases LOCK# when access is terminated by target-abort or master-abort. (section 3.6)                                          | _            |    |
| 26  | IUT always deasserts LOCK# for minimum of one idle cycle between consecutive lock operations. (section 3.6)                                 | _            |    |
| 27  | IUT always uses linear burst ordering for configuration cycles. (section 3.7.4)                                                             | $\checkmark$ |    |
| 28  | IUT always drives par within one clock of cben[30] and ad[310] being driven. (section 3.8.1)                                                | ✓            |    |
| 29  | IUT always drives par such that the number of "1"s on ad[310], cben[30], and par equals an even number. (section 3.8.1)                     | $\checkmark$ |    |

| Table | able 37. Component Master Checklist (Part 3 of 3)                                                                                     |     |    |
|-------|---------------------------------------------------------------------------------------------------------------------------------------|-----|----|
| MP#   | Requirement                                                                                                                           | Yes | No |
| 30    | IUT always drives perrn (when enabled) active two clocks after data when data parity error is detected. (section 3.8.2.1)             | ~   |    |
| 31    | IUT always drives PERR (when enabled) for a minimum of 1 clock for each data phase that a parity error is detected. (section 3.8.2.1) | ~   |    |
| 32    | IUT always holds framen asserted for cycle following DUAL command. (section 3.10.1)                                                   | —   |    |
| 33    | IUT never generates DUAL cycle when upper 32-bits of address are zero. (section 3.10.1)                                               | —   |    |

# Table 38. Component Target Checklist (Part 1 of 2)

| TP# | Requirement                                                                                                                       | Yes          | No |
|-----|-----------------------------------------------------------------------------------------------------------------------------------|--------------|----|
| 1   | All sustained tri-state signals are driven high for one clock before being tri-stated. (section 2.1)                              | ~            |    |
| 2   | IUT never reports perrn until it has claimed the cycle and completed a data phase. (section 2.2.5)                                | ~            |    |
| 3   | IUT never aliases reserved commands with other commands. (section 3.1.1)                                                          | —            |    |
| 4   | 32-bit addressable IUT treats DUAL command as reserved. (section 3.1.1)                                                           | _            |    |
| 5   | Once IUT has asserted trdyn it never changes trdyn until the data phase completes. (section 3.2.1)                                | ~            |    |
| 6   | Once IUT has asserted trdyn it never changes devseln until the data phase completes. (section 3.2.1)                              | ~            |    |
| 7   | Once IUT has asserted $trdyn$ it never changes stopn until the data phase completes. (section 3.2.1)                              | ~            |    |
| 8   | Once IUT has asserted stopn it never changes stopn until the data phase completes. (section 3.2.1)                                | ~            |    |
| 9   | Once IUT has asserted stopn it never changes trdyn until the data phase completes. (section 3.2.1)                                | ~            |    |
| 10  | Once IUT has asserted stopn it never changes devseln until the data phase completes. (section 3.2.1)                              | ~            |    |
| 11  | IUT only transfers data when both irdyn and trdyn are asserted on the same rising clock edge. (section 3.2.1)                     | ~            |    |
| 12  | IUT always asserts trdyn when data is valid on a read cycle. (section 3.2.1)                                                      | $\checkmark$ |    |
| 13  | IUT always signals target-abort when unable to complete the entire I/O access as defined by the byte enables. (section 3.2.2)     | —            |    |
| 14  | IUT never responds to reserved encodings. (section 3.2.2)                                                                         | $\checkmark$ |    |
| 15  | IUT always ignores configuration command unless <code>idsel</code> is asserted and <code>ad[310]</code> are "00". (section 3.2.2) | ~            |    |

| TP# | Requirement                                                                                                                                    | Yes          | No |
|-----|------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|
| 16  | IUT always disconnects after the first data phase when reserved burst mode is detected. (section 3.2.2)                                        |              |    |
| 17  | The IUT's ad[310] lines are driven to stable values during every address and data phase. (section 3.2.4)                                       | >            |    |
| 18  | The IUT's cben[30] output buffers remain enabled from the first clock of the data phase through the end of the transaction. (section 3.3.1)    |              |    |
| 19  | IUT never asserts trdyn during turnaround cycle on a read. (section 3.3.1)                                                                     |              |    |
| 20  | IUT always deasserts trdyn, stopn, and devseln the clock following the completion of the last data phase. (section 3.3.3.2)                    | >            |    |
| 21  | IUT always signals disconnect when burst crosses resource boundary. (section 3.3.3.2)                                                          | —            |    |
| 22  | IUT always deasserts stopn the cycle immediately following framen being deasserted. (section 3.3.3.2.1)                                        | >            |    |
| 23  | Once the IUT has asserted stopn it never deasserts stopn until framen is negated. (section 3.3.3.2.1)                                          | >            |    |
| 24  | IUT always deasserts trdyn before signaling target-abort. (section 3.3.3.2.1)                                                                  | _            |    |
| 25  | IUT never deasserts stopn and continues the transaction. (section 3.3.3.2.1)                                                                   | <            |    |
| 26  | IUT always completes initial data phase within 16 clocks. (section 3.5.1.1)                                                                    | >            |    |
| 27  | IUT always locks minimum of 16 bytes. (section 3.6)                                                                                            | _            |    |
| 28  | IUT always issues devseln before any other response. (section 3.7.1)                                                                           | >            |    |
| 29  | Once IUT has asserted devseln it never deasserts devseln until the last data phase has competed except to signal target-abort. (section 3.7.1) | >            |    |
| 30  | IUT never responds to special cycles. (section 3.7.2)                                                                                          | <            |    |
| 31  | IUT always drives par within one clock of cben[30] and ad[310] being driven. (section 3.8.1)                                                   | ~            |    |
| 32  | IUT always drives par such that the number of "1"s on ad[310], cben[30], and par equals an even number. (section 3.8.1)                        | $\checkmark$ |    |

# PCI SIG Test Bench Summary

Tables 39 through 56 list the applicable PCI SIG test bench scenarios from the *PCI Compliance Checklist, Rev.* 2.1. A check mark in the yes column indicates that the pci\_a meets the requirement. Checklists not applicable to the Altera FLEX 10K pci\_a function are not listed.

| #  | Requirement                                                                | Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | No |
|----|----------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| 1  | Data transfer after write to fast memory slave.                            | <ul> <li>Image: A start of the start of</li></ul> |    |
| 2  | Data transfer after read from fast memory slave.                           | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 3  | Data transfer after write to medium memory slave.                          | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 4  | Data transfer after read from medium memory slave.                         | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 5  | Data transfer after write to slow memory slave.                            | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 6  | Data transfer after read from slow memory slave.                           | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 7  | Data transfer after write to subtractive memory slave.                     | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 8  | Data transfer after read from subtractive memory slave.                    | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 9  | Master abort bit set after write to slower than subtractive memory slave.  | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 10 | Master abort bit set after read from slower than subtractive memory slave. |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |

### Table 40. Test Scenario: 1.2 PCI Bus Target Abort Cycles (Part 1 of 2)

| # | Requirement                                                     | Yes                   | No |
|---|-----------------------------------------------------------------|-----------------------|----|
| 1 | Target abort bit set after write to fast memory slave.          | $\checkmark$          |    |
| 2 | IUT does not repeat the write transaction.                      | $\checkmark$          |    |
| 3 | IUT's target abort bit set after read from fast memory slave.   | $\checkmark$          |    |
| 4 | IUT does not repeat the read transaction.                       | $\checkmark$          |    |
| 5 | Target abort bit set after write to medium memory slave.        | $\checkmark$          |    |
| 6 | IUT does not repeat the write transaction.                      | $\checkmark$          |    |
| 7 | IUT's target abort bit set after read from medium memory slave. | ~                     |    |
| 8 | IUT does not repeat the read transaction.                       | ~                     |    |
| 9 | Target abort bit set after write to slow memory slave.          | <ul> <li>✓</li> </ul> |    |

| #  | Requirement                                                          | Yes                   | No |
|----|----------------------------------------------------------------------|-----------------------|----|
| 10 | IUT does not repeat the write transaction.                           | ~                     |    |
| 11 | IUT's target abort bit set after read from slow memory slave.        | ~                     |    |
| 12 | IUT does not repeat the read transaction.                            | ~                     |    |
| 13 | Target abort bit set after write to subtractive memory slave.        | ~                     |    |
| 14 | IUT does not repeat the write transaction.                           | <ul> <li>✓</li> </ul> |    |
| 15 | IUT's target abort bit set after read from subtractive memory slave. | ✓                     |    |
| 16 | IUT does not repeat the read transaction.                            |                       |    |

| # | Requirement                                             | Yes                   | No |
|---|---------------------------------------------------------|-----------------------|----|
| 1 | Data transfer after write to fast memory slave.         | <ul> <li>✓</li> </ul> |    |
| 2 | Data transfer after read from fast memory slave.        | <ul> <li>✓</li> </ul> |    |
| 3 | Data transfer after write to medium memory slave.       | <ul> <li>✓</li> </ul> |    |
| 4 | Data transfer after read from medium memory slave.      | <ul> <li>✓</li> </ul> |    |
| 5 | Data transfer after write to slow memory slave.         | <ul> <li>✓</li> </ul> |    |
| 6 | Data transfer after read from slow memory slave.        | <ul> <li>✓</li> </ul> |    |
| 7 | Data transfer after write to subtractive memory slave.  | ✓                     |    |
| 8 | Data transfer after read from subtractive memory slave. |                       |    |

| # | Requirement                                        | Yes                   | No |
|---|----------------------------------------------------|-----------------------|----|
| 1 | Data transfer after write to fast memory slave.    | <ul> <li>✓</li> </ul> |    |
| 2 | Data transfer after read from fast memory slave.   | <ul> <li>✓</li> </ul> |    |
| 3 | Data transfer after write to medium memory slave.  | <ul> <li>✓</li> </ul> |    |
| 4 | Data transfer after read from medium memory slave. | <ul> <li>✓</li> </ul> |    |
| 5 | Data transfer after write to slow memory slave.    | ✓                     |    |

| Table 42. Test Scenario: 1.4 PCI Bus Single Data Phase Retry Cycles (Part 2 of 2) |                                                         |     |    |  |
|-----------------------------------------------------------------------------------|---------------------------------------------------------|-----|----|--|
| #                                                                                 | Requirement                                             | Yes | No |  |
| 6                                                                                 | Data transfer after read from slow memory slave.        | ~   |    |  |
| 7                                                                                 | Data transfer after write to subtractive memory slave.  | ~   |    |  |
| 8                                                                                 | Data transfer after read from subtractive memory slave. | ~   |    |  |

| Table 43. Test Scenario: 1.5 PCI Bus Single Data Phase Disconnect Cycles |                                                                      |                       |    |  |
|--------------------------------------------------------------------------|----------------------------------------------------------------------|-----------------------|----|--|
| #                                                                        | Requirement                                                          | Yes                   | No |  |
| 1                                                                        | Target abort bit set after write to fast memory slave.               | $\checkmark$          |    |  |
| 2                                                                        | IUT does not repeat the write transaction.                           | ~                     |    |  |
| 3                                                                        | IUT's target abort bit set after read from fast memory slave.        | <ul> <li>✓</li> </ul> |    |  |
| 4                                                                        | IUT does not repeat the read transaction.                            | <ul> <li>✓</li> </ul> |    |  |
| 5                                                                        | Target abort bit set after write to medium memory slave.             | <ul> <li>✓</li> </ul> |    |  |
| 6                                                                        | IUT does not repeat the write transaction.                           | <ul> <li>✓</li> </ul> |    |  |
| 7                                                                        | IUT's target abort bit set after read from medium memory slave.      | <ul> <li>✓</li> </ul> |    |  |
| 8                                                                        | IUT does not repeat the read transaction.                            | <ul> <li>✓</li> </ul> |    |  |
| 9                                                                        | Target abort bit set after write to slow memory slave.               | <ul> <li>✓</li> </ul> |    |  |
| 10                                                                       | IUT does not repeat the write transaction.                           | <ul> <li>✓</li> </ul> |    |  |
| 11                                                                       | IUT's target abort bit set after read from slow memory slave.        | <ul> <li>✓</li> </ul> |    |  |
| 12                                                                       | IUT does not repeat the read transaction.                            | <ul> <li>✓</li> </ul> |    |  |
| 13                                                                       | Target abort bit set after write to subtractive memory slave.        | <ul> <li>✓</li> </ul> |    |  |
| 14                                                                       | IUT does not repeat the write transaction.                           | <ul> <li>✓</li> </ul> |    |  |
| 15                                                                       | IUT's target abort bit set after read from subtractive memory slave. | <ul> <li>✓</li> </ul> |    |  |
| 16                                                                       | IUT does not repeat the read transaction.                            | <ul> <li>✓</li> </ul> |    |  |

| # | Requirement                                             | Yes                   | No |
|---|---------------------------------------------------------|-----------------------|----|
| 1 | Data transfer after write to fast memory slave.         | <ul> <li>✓</li> </ul> |    |
| 2 | Data transfer after read from fast memory slave.        | <ul> <li>✓</li> </ul> |    |
| 3 | Data transfer after write to medium memory slave.       | <ul> <li>✓</li> </ul> |    |
| 4 | Data transfer after read from medium memory slave.      | <ul> <li>✓</li> </ul> |    |
| 5 | Data transfer after write to slow memory slave.         | <ul> <li>✓</li> </ul> |    |
| 6 | Data transfer after read from slow memory slave.        | <ul> <li>✓</li> </ul> |    |
| 7 | Data transfer after write to subtractive memory slave.  | ✓                     |    |
| 8 | Data transfer after read from subtractive memory slave. |                       |    |

| # | Requirement                                             | Yes                   | No |
|---|---------------------------------------------------------|-----------------------|----|
| 1 | Data transfer after write to fast memory slave.         | <ul> <li>✓</li> </ul> |    |
| 2 | Data transfer after read from fast memory slave.        | ~                     |    |
| 3 | Data transfer after write to medium memory slave.       | ~                     |    |
| 4 | Data transfer after read from medium memory slave.      | ~                     |    |
| 5 | Data transfer after write to slow memory slave.         | ~                     |    |
| 6 | Data transfer after read from slow memory slave.        | ~                     |    |
| 7 | Data transfer after write to subtractive memory slave.  | ✓                     |    |
| 8 | Data transfer after read from subtractive memory slave. |                       |    |

| Table 46. Test Scenario: 1.8 PCI Bus Multi-Data Phase & trdyn Cycles (Part 1 of 2) |                                                                                                                                                           |              |    |  |
|------------------------------------------------------------------------------------|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|--|
| #                                                                                  | Requirement                                                                                                                                               | Yes          | No |  |
| 1                                                                                  | Verify that data is written to primary target when trdynis released after second rising clock edge and asserted on third rising clock edge after framen.  | $\checkmark$ |    |  |
| 2                                                                                  | Verify that data is read from primary target when trdyn is released after second rising clock edge and asserted on third rising clock edge after framen.  | ~            |    |  |
| 3                                                                                  | Verify that data is written to primary target when trdyn is released after third rising clock edge and asserted on fourth rising clock edge after framen. | ~            |    |  |

| #  | Requirement                                                                                                                                               | Yes          | No |
|----|-----------------------------------------------------------------------------------------------------------------------------------------------------------|--------------|----|
| 4  | Verify that data is read from primary target when trdyn is released after third rising clock edge and asserted on fourth rising clock edge after framen.  | $\checkmark$ |    |
| 5  | Verify that data is written to primary target when trdyn is released after third rising clock edge and asserted on fifth rising clock edge after framen.  | $\checkmark$ |    |
| 6  | Verify that data is read from primary target when trdyn is released after third rising clock edge and asserted on fifth rising clock edge after framen.   | $\checkmark$ |    |
| 7  | Verify that data is written to primary target when trdyn is released after fourth rising clock edge and asserted on sixth rising clock edge after framen. | $\checkmark$ |    |
| 8  | Verify that data is read from primary target when trdyn is released after fourth rising clock edge and asserted on sixth rising clock edge after framen.  | ✓            |    |
| 9  | Verify that data is written to primary target when trdyn alternately released for one clock cycle and asserted for one clock cycle after framen.          | ~            |    |
| 10 | Verify that data is read from primary target when trdyn alternately released for one clock cycle and asserted for one clock cycle after framen.           | $\checkmark$ |    |
| 11 | Verify that data is written to primary target when trdyn alternately released for two clock cycles and asserted for two clock cycles after framen.        | $\checkmark$ |    |
| 12 | Verify that data is read from primary target when trdyn alternately released for two clock cycles and asserted for two clock cycles after framen.         | $\checkmark$ |    |

| Table 47. Test Scenario: 1.9 PCI Bus Data Parity Error Single Cycles |                                                                                                              |     |    |  |
|----------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------|-----|----|--|
| #                                                                    | Requirement                                                                                                  | Yes | No |  |
| 1                                                                    | Verify the IUT sets data parity error detected bit when primary target asserts perrn on IUT memory write.    | ~   |    |  |
| 2                                                                    | Verify that perrn is active two clocks after the first data phase (which had odd parity) on IUT memory read. | ~   |    |  |
| 3                                                                    | Verify the IUT sets parity error detected bit when odd parity is detected on IUT memory read.                | ~   |    |  |

| Table 48. Test Scenario: 1.10 PCI Bus Data Parity Error Multi-Data Phase Cycles |                                                                                                                               |              |    |  |
|---------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------|--------------|----|--|
| #                                                                               | Requirement                                                                                                                   | Yes          | No |  |
| 1                                                                               | Verify the IUT sets parity error detected bit when primary target asserts perrn on IUT multi-data phase memory write.         | $\checkmark$ |    |  |
| 2                                                                               | Verify that perrn is active two clocks after the first data phase (which had odd parity) on IUT multi-data phase memory read. | $\checkmark$ |    |  |
| 3                                                                               | Verify the IUT sets parity error detected bit when odd.                                                                       | $\checkmark$ |    |  |

| Table 49. Test Scenario: 1.11 PCI Bus Master Time-Out |                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
|-------------------------------------------------------|---------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| #                                                     | Requirement                                                         | Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | No |
| 1                                                     | Memory write transaction terminates before 4 data phases completed. | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 2                                                     | Memory read transaction terminates before 4 data phases completed.  | <ul> <li>Image: A start of the start of</li></ul> |    |

| Table 50. Test Scenario: 1.13 PCI Bus Master Parking |                                                                       |              |  |  |  |
|------------------------------------------------------|-----------------------------------------------------------------------|--------------|--|--|--|
| #                                                    | Requirement                                                           | Yes          |  |  |  |
| 1                                                    | IUT drives ad[310] to stable values within eight PCI clocks of gntn.  | ~            |  |  |  |
| 2                                                    | IUT drives cben[30] to stable values within eight PCI clocks of gntn. | ~            |  |  |  |
| 3                                                    | IUT drives par one clock cycle after IUT drives ad[310]               | ~            |  |  |  |
| 4                                                    | IUT tri-states ad[310] and cben[30] and par when gntn is released.    | $\checkmark$ |  |  |  |

| Table 51. Test Scenario: 1.14 PCI Bus Master Arbitration |                                                                                      |     |    |
|----------------------------------------------------------|--------------------------------------------------------------------------------------|-----|----|
| #                                                        | Requirement                                                                          | Yes | No |
| 1                                                        | IUT completes transaction when deasserting gntn is coincident with asserting framen. | ~   |    |

| Table 52. Test Scenario: 2.5 Target Ignores Reserved Commands |                                                      |              |    |
|---------------------------------------------------------------|------------------------------------------------------|--------------|----|
| #                                                             | Requirement                                          | Yes          | No |
| 1                                                             | IUT does not respond to RESERVED COMMANDS.           | $\checkmark$ |    |
| 2                                                             | Initiator detects master abort for each transfer.    | $\checkmark$ |    |
| 3                                                             | IUT does not respond to 64-bit cycle (dual address). | $\checkmark$ |    |

| Table 53. Test Scenario: 2.6 Target Receives Configuration Cycles |                                                                                  |              |    |
|-------------------------------------------------------------------|----------------------------------------------------------------------------------|--------------|----|
| #                                                                 | Requirement                                                                      | Yes          | No |
| 1                                                                 | IUT responds to all configuration cycles type 0 read/write cycles appropriately. | $\checkmark$ |    |
| 2                                                                 | IUT does not respond to configuration cycles type 0 with idsel inactive.         | $\checkmark$ |    |

No

| Table 54. Test Scenario: 2.8 Target Receives Configuration Cycles with Address and Data Parity Errors |                                                                                    |     |    |
|-------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------|-----|----|
| #                                                                                                     | Requirement                                                                        | Yes | No |
| 1                                                                                                     | IUT reports address parity error via serrn during configuration read/write cycles. | ✓   |    |
| 2                                                                                                     | IUT reports data parity error via PERR during configuration write cycles.          | ✓   |    |

| Table 5 | Table 55. Test Scenario: 2.9 Target Receives Memory Cycles       |              |    |
|---------|------------------------------------------------------------------|--------------|----|
| #       | Requirement                                                      | Yes          | No |
| 1       | IUT completes single memory read and write cycles appropriately. | $\checkmark$ |    |

| Table 56. Test Scenario: 2.10 Target Receives Memory Cycles with Address and Data Parity Errors |                                                                                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |    |
|-------------------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|----|
| #                                                                                               | Requirement                                                                         | Yes                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                 | No |
| 1                                                                                               | IUT reports address parity error via serrn during all memory read and write cycles. | ~                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   |    |
| 2                                                                                               | IUT reports data parity error via PERR during all memory write cycles.              | <ul> <li>Image: A start of the start of</li></ul> |    |

# References

Reference documents for the pci\_a include:

- PCI Local Bus Specification. Rev. 2.1. Portland, Oregon: PCI Special Interest Group, June 1995
- **PCI** Compliance Checklist. Rev 2.1. Portland, Oregon: review copy.
- Altera 1996 Data Book. San Jose, California. June 1996.
- IEEE Standard VHDL Language Reference Manual. ANSI/IEEE Std 1076-1993. New York, New York. June 1994.



2610 Orchard Parkway San Jose, CA 95134-2020 (408) 544-7000 http://www.altera.com Applications Hotline: (800) 800-EPLD Customer Marketing:

(408) 894-7104 Literature Services: (408) 894-7144 lit\_req@altera.com Altera, FLEX, FLEX 10K, EPF10K130V, AHDL, MegaCore, OpenCore, MAX, MAX+PLUS, and MAX+PLUS II are trademarks and/or service marks of Altera Corporation in the United States and other countries. Altera acknowledges the trademarks of other organizations for their respective products or services mentioned in this document. Altera products are protected under numerous U.S. and foreign patents and pending applications, maskwork rights, and copyrights. Altera warrants performance of its semiconductor products to current specifications in accordance with Altera's standard warranty, but reserves the right to make changes to any products and services at any time without notice. Altera assumes no responsibility or

liability arising out of the application or use of any information, product, or service described herein except as expressly agreed to in writing by Altera Corporation. Altera customers are advised to obtain the latest version of device specifications before relying on any published information and before placing orders for products or services.



Copyright © 1997 Altera Corporation. All rights reserved.

Altera Corporation

